登陆+注册(三层+sql语句)

啰嗦:今天面试,遇到这个上级测试,很容易的,因为一个错误,居然最后没做出来,心累

回到家,1小时做完,我特么还加了密,我还验证,可是上天不给我一次重来的机会啊

很垃圾的,小白可以看看,大神可以轻喷

首先第一个问题就是:数据库字段的设计

nvarchar  与 varchar的区别

nvarhar:添加字段,自动用空格补齐后面的空余

varvhar:无空格

问题出现的原因:登陆判断时,输入文本框的值和数据库一样却报错,发现原来是有空格

最简单的数据库表设计

然后就是添加sql帮助类库

model代码:model有输入验证记得在model类库引用 using System.ComponentModel.DataAnnotations;

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Web;

namespace Model
{
    public class UserModel
    {
        [DisplayName("用户名")]
        [Required(ErrorMessage = "必填")]
        public string UserName { get; set; }

        [DisplayName("密码")]
        [Required(ErrorMessage = "必填")]
        [StringLength(20, MinimumLength = 6, ErrorMessage = "密码长度必须在{2} 和{1}个字符")]
        [DataType(DataType.Password)]
        public string UserPwd { get;set; }

        public string ConfirmPassword { get; set; }
        public string Message { get; set; }
    }
}

model代码

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using YL.MySQL;

namespace DAL
{
    public class UserDAL
    {

        //注册
        public bool regst(string UserName, string UserPwd)
        {
            StringBuilder sql =new StringBuilder();
            sql.Append("INSERT INTO Users (UserName,UserPwd) VALUES (@UserName,@UserPwd)" );
            SqlParameter[] sqlparmeter =
            {
                new SqlParameter("@UserName",SqlDbType.NVarChar,50),
                new SqlParameter("@UserPwd",SqlDbType.NVarChar,50)

                                         };
            sqlparmeter[0].Value = UserName;
            sqlparmeter[1].Value = UserPwd;
            var result = new MySqlAdoProvide().ExecuteNonQuery(MySqlHelper.connectionStringManager, sql.ToString(), sqlparmeter) > 0;
            return result;           

        }
        //登陆
        public Model.UserModel GetLogin(string UserName)
        {
            StringBuilder strSql = new StringBuilder();
            strSql.Append("select UserName,UserPwd " );
            strSql.Append("  from Users ");
            strSql.Append(" where [email protected] ");
            SqlParameter[] parameters = {
                    new SqlParameter("@UserName", SqlDbType.NVarChar,50)
            };
            parameters[0].Value = UserName;
            var data = new MySqlAdoProvide().ExecuteReader(dr => dr.GetEntity<Model.UserModel>(), MySqlHelper.connectionStringManager, strSql.ToString(), parameters).FirstOrDefault();
            return data;
        }
    }
}

DAL代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace BLL
{
    public class UserBLL
    {
        //构造函数
        private DAL.UserDAL dal;
        public UserBLL()
        {
            dal = new DAL.UserDAL();
        }
        //注册
        public bool regst(string UserName, string UserPwd)
        {
            return dal.regst(UserName, UserPwd);
        }
        public Model.UserModel GetLogin(string UserName)
        {
            return dal.GetLogin(UserName);
        }
    }
}

BLL代码

MvcApplication8-HomeController代码

控制器代码

@model Model.UserModel
@{
    ViewBag.Title = "Index";
}

<h2>登陆界面</h2>
<div>
    @using(Html.BeginForm("Login","Home",FormMethod.Post))
    {
        <div>
                 @Html.TextBoxFor(m => m.UserName, new { @class = "form-control", @placeholder = "用户名" })
                    @Html.ValidationMessageFor(m => m.UserName)
              @Html.TextBoxFor(m => m.UserPwd, new { @class = "form-control", @placeholder = "密码" })
                    @Html.ValidationMessageFor(m => m.UserPwd)
            <button type="submit">登陆</button>
               @Html.ValidationMessageFor(m => m.Message)
         <a href="@Url.Action("regist")">注册一个新账号</a>
            </div>
        }
</div>

登陆界面代码

@model Model.UserModel
@{
    ViewBag.Title = "Index";
}

<h2>注册界面</h2>
<div>
    @using(Html.BeginForm("zc","Home",FormMethod.Post))
    {
        <div>
  @Html.TextBoxFor(m => m.UserName, new {  @placeholder = "用户名" })
                    @Html.ValidationMessageFor(m => m.UserName)

              @Html.TextBoxFor(m => m.UserPwd, new { @placeholder = "密码" })
                    @Html.ValidationMessageFor(m => m.UserPwd)
            @Html.TextBoxFor(m => m.ConfirmPassword, new { @placeholder="确认密码"})
            @Html.ValidationMessageFor(m=>m.ConfirmPassword)
               @Html.ValidationMessageFor(m => m.Message)
            <button type="submit">注册</button>

            </div>
        }
</div>

注册界面代码

时间: 2024-08-27 16:12:45

登陆+注册(三层+sql语句)的相关文章

Android的SQLiteDataBase小项目,实现user类登陆注册以及student类增删改查

关于SQLiteDataBase这块,大体有两种主要的实现方式,一种是不使用Helper类的方式,此种方式存在一个弊端,即不能oncreate两次,如果重复使用oncreate的button,则会报错,所以为了避免这种错误,在此项目中使用类继承SQLiteOpenHelper的方式进行SQLite3小型数据库的小项目开发,简单的实现登陆注册,以及对特定vo类的增删改查,中间还夹杂了ListView,ArrayAdapter,以及Intent的散知识点. 以下为正文:首先介绍以下我写的项目的框架,

PLSQL执行sql语句输出的中文是???之解决方法和步骤

方法/步骤 1 登陆plsql,执行sql语句,输出的中文标题显示成问号????:条件包含中文,则无数据输出 步骤阅读 2 输入sql语句select * from V$NLS_PARAMETERS查看字符集,查看第一行value值是否为简体中文 步骤阅读 3 进入注册表,依次单击HKEY_LOCAL_MACHINE --->SOFTWARE ---> ORACLE--->home(小编安装的是Oracle 11g,这里显示成KEY_OraDb11g_home1),找到NLS_LANG,

Python tkinter 实现简单登陆注册 基于B/S三层体系结构,实现用户身份验证

Python tkinter 实现简单登陆注册 最终效果 开始界面 ? 注册 登陆 ? 源码 login.py # encoding=utf-8 from tkinter import * from tkinter import messagebox as tkMessageBox import mysql_connect as mys import pymysql import base64 #加密 将用户的密码加密后储存到数据库 def encryption(str): str=str.en

用sql语句来修改sa用户的登陆密码

用sql语句来修改sa用户的登陆密码. 步骤一: 打开sql server manager studio,用Windows验证登陆,新建查询,执行以下语句: 步骤二: 1)打开对象资源管理器视图,在数据库链接上右键->属性. 2)在打开的窗口点击安全性,将sql server和windows身份验证模式勾上. 3)展开安全性菜单,将登陆名下的sa属性-状态-登陆-启用 alter login sa with password=’你的新密码’ 3然后把mssql server服务重启一下,很重要!

实用SQL语句

一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack 4.说明:创建

sql语句大全

sql语句大全1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'--- 开始 备份BACKUP DATABASE pubs TO testBack4.说明:创建新表create

经典SQL语句

经典SQL语句大全(绝对的经典) 一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'--- 开始 备份BACKUP DATABASE pubs TO testBa

实用SQL语句大全

一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack 4.说明:创建

经典SQL语句大全

转自 http://www.cnblogs.com/yubinfeng/archive/2010/11/02/1867386.html 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数据的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_