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

回到家,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(, MinimumLength = , 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 =
            {
                ),
                )

                                         };
            sqlparmeter[].Value = UserName;
            sqlparmeter[].Value = UserPwd;
            ;
            return result;           

        }
        //登陆
        public Model.UserModel GetLogin(string UserName)
        {
            StringBuilder strSql = new StringBuilder();
            strSql.Append("select UserName,UserPwd " );
            strSql.Append("  from Users ");
            strSql.Append(" where UserName=@UserName ");
            SqlParameter[] parameters = {
                    )
            };
            parameters[].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>

注册界面代码

 
 

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

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

    方法/步骤 1 登陆plsql,执行sql语句,输出的中文标题显示成问号????:条件包含中文,则无数据输出 步骤阅读 2 输入sql语句select * from V$NLS_PARAMETERS查 ...

  2. 浅谈c#的三个高级参数ref out 和Params C#中is与as的区别分析 “登陆”与“登录”有何区别 经典SQL语句大全(绝对的经典)

    浅谈c#的三个高级参数ref out 和Params   c#的三个高级参数ref out 和Params 前言:在我们学习c#基础的时候,我们会学习到c#的三个高级的参数,分别是out .ref 和 ...

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

    Python tkinter 实现简单登陆注册 最终效果 开始界面 ​ 注册 登陆 ​ 源码 login.py # encoding=utf-8 from tkinter import * from ...

  4. sql语句去重 最后部分没看 看1 有用

    一 数据库 1.常问数据库查询.修改(SQL查询包含筛选查询.聚合查询和链接查询和优化问题,手写SQL语句,例如四个球队比赛,用SQL显示所有比赛组合:举例2:选择重复项,然后去掉重复项:) 数据库里 ...

  5. Spring Boot+Jpa(MYSQL)做一个登陆注册系统(前后端数据库一站式编程)

    Spring Boot最好的学习方法就是实战训练,今天我们用很短的时间启动我们第一个Spring Boot应用,并且连接我们的MySQL数据库. 我将假设读者为几乎零基础,在实战讲解中会渗透Sprin ...

  6. Android通过Http连接MySQL 实现登陆/注册(数据库+服务器+客户端)

    写在最前: 在实际开发中,相信每个项目都会有用户登陆注册功能,这个实现的方法很多,下面是我实现的方法,供大家交流. 新人发帖,万分紧张,怎么样才能装作一副经常发帖的样子不被别人看出来呢-,- ? 好了 ...

  7. SQL语句大全

    经典SQL语句大全(绝对的经典) 一.基础 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份s ...

  8. 实用SQL语句大全

    一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- ...

  9. 经典SQL语句大全

    一.基础 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备 ...

随机推荐

  1. selenium设置Chrome

    关闭图片 from selenium import webdriver options = webdriver.ChromeOptions() prefs = { 'profile.default_c ...

  2. PHP eof的使用

    PHP eof的使用 也就是heredoc技术,来部分实现界面与代码的分离 <?php $name = '张三'; print <<<EOT <html> < ...

  3. 【svn】svn 项目地址修改

    1.IDEA修改 确定OK. 2.TortoiseSVN修改 选择项目目录右键->TortoiseSVN->重新定位(Relocate),然后修改URL, 3.Mac OS或Linux客户 ...

  4. Linux----LVM扩容磁盘空间

    Linux系统LVM扩容一个分区相对于Windows来说没有那么直观,但是熟悉命令后,扩容起来也是蛮方便的. 扩容场景如下: [root@rhel06 ~]# df -Th Filesystem Ty ...

  5. [2014.01.27]wfRadar 雷达图组件 2.5

    全新开发的雷达图组件--wfRadar,使用简单,功能强大,图像处理效果极佳. 组件支持多种图片格式,包括bmp,jpg,gif,wmf,emf,ico,png,pcx,tif,tga,pcx,dcx ...

  6. 如何区分Babel中的stage-0,stage-1,stage-2以及stage-3(一)

    大家知道,将ES6代码编译为ES5时,我们常用到Babel这个编译工具.大家参考一些网上的文章或者官方文档,里面常会建议大家在.babelrc中输入如下代码: { "presets" ...

  7. pickle序列化

    通过pickle来序列化: # -*- coding: utf-8 -*- import pickle #-------------------序列化--------------------- zoo ...

  8. 营业额统计(SBT)

    营业额统计(SBT) #include<cstdio> #include<cstring> #include<string> #include<cstdlib ...

  9. ios7 tableview scrollsToTop 不执行处理方法

    ios7中调用[self.tableview scrollsToTop] 没有效果(ios8中也没有效果) stackflow 处理方法: [self.tableviewscrollRectToVis ...

  10. HBase设计与开发性能优化(转)

    本文主要是从HBase应用程序设计与开发的角度,总结几种常用的性能优化方法.有关HBase系统配置级别的优化,这里涉及的不多,这部分可以参考:淘宝Ken Wu同学的博客. 1. 表的设计 1.1 Pr ...