结合sqlite数据库,完善asp.net制作的web网页中的注册和登录操作。

1. Account-Register.aspx

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<dynamic>" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
<title>注册页面</title>
<script src="../../Scripts/Common/JScript.js" type="text/javascript"></script>
</asp:Content> <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> 用  户:<input id="name" type="text"/><br /><br />
密  码:<input id="pwd1" type="text"/><br /><br />
确认密码:<input id="pwd2" type="text"/><br /><br />
验 证 码:<input id="code" type="text"/><br /><br />
<img id="vimg" src="/Common/Image" onclick="changeImage()" />
<input type="button" onclick="Register()" value="注册"/>
<label id="showRegister" style="color:Red"></label> </asp:Content>

这里的页面采用了微软新建项目自带的母版格式。注册页有用户、密码、确认密码、图片验证码和注册按钮。

2. 点击注册按钮 onclick="Register()" 事件,保存在Scripts-Common-JScript.js中

function Register() {
var name = $("#name").val();
var pwd1 = $("#pwd1").val();
var pwd2 = $("#pwd2").val();
var code = $("#code").val();
//前台校验过滤
if (name != "") {
$.post("/Account/DoRegister", { name: name, pwd1: pwd1, pwd2: pwd2, code: code },
function (data) {
if (data == "0") {
$("#showRegister").html("注册成功");
window.location.href = "/account/login";
}
else if (data == "-1") {
$("#showRegister").html("用户名或密码为空");
}
else if (data == "-2") {
$("#showRegister").html("密码输入错误");
}
else if (data == "-3") {
$("#showRegister").html("用户名已存在");
}
else if (data == "-4") {
$("#showRegister").html("验证码错误");
}
});
}
else {
$("#showRegister").html("用户名为空");
} } function changeImage() {
var imgNode = document.getElementById("vimg");
imgNode.src = "/Common/Image/" + (new Date()).valueOf(); //加上时间的参数防止浏览器缓存
}

function Register()是前后台逻辑判断,前台通过$("#id").val()的方式获取id的值,后台利用request.form["name"]的形式接收,提示结果显示在id="showRegister"的<lable>上。jQuery通过ajax异步传输post,将值对交给后台判断"/Account/DoRegister"

function changeImage()是为了点击图片验证码,自变换的点击事件。通过对验证码vimg,加上时间参数来改变src的方式进行改变。
3. 后台逻辑判断 AccountController.cs

public ActionResult DoRegister()
{
string name = Request.Form["name"];
string pwd1 = Request.Form["pwd1"];
string pwd2 = Request.Form["pwd2"];
string code = Request.Form["code"]; //验证码
//后台验证
int res = ;
string checkCode = Session["Code"].ToString(); if (string.IsNullOrEmpty(name) || string.IsNullOrEmpty(pwd1))
{
res = -;
}
else if (pwd1 != pwd2)
{
res = -;
}
else if (code.ToLower() != checkCode.ToLower()) //验证码全部转为小写
{
res = -;
}
else
{
//判断用户是否已经存在
List<MVCStudy.Model.User> userList = userBll.GetModelList("name= '" + name + "' and pwd= '" + pwd1 + "'");
if (userList.Count != )
{
res = -;
}
else {
//插入数据""
MVCStudy.Model.User userModel = new Model.User();
userModel.Name = name;
userModel.Pwd = pwd1;
userModel.AddTime = DateTime.Now.ToString();
userBll.Add(userModel);
}
}
return Content(res.ToString());
}

前提已经建好User的sqlite数据库表,里面存放了name和pwd,用户名和密码。再次确认密码和密码做比较,图片验证码存放在session["Code"]中,与输入的code做比较,且比较时全部转为小写字母,不区分大小写。将注册输入符合规范且图片验证码输入正确的,先判断是否已经在数据库中存在,若存在则提示“该用户已存在,请直接登录”,否则,则添加到数据库中,并提示用户添加成功,并跳转到登录页面。

4. Account-Login.aspx

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<dynamic>" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
<title>登录页面</title>
<script src="../../Scripts/Common/JScript.js" type="text/javascript"></script>
</asp:Content> <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> 用  户:<input id="name" type="text"/><br /><br />
密  码:<input id="pwd1" type="text"/><br /><br />
<%--<img id="vimg" src="/Common/Image" onclick="changeImage()" />--%>
<input type="button" onclick="Login()" value="登录"/>
<label id="showLogin" style="color:Red"></label> </asp:Content>

登录页面比较简单,只有用户、密码和登录按钮。(利用刚刚注册的用户c登录成功)

5. 登录按钮 onclick="Login()" 事件:

function Login() {
var name = $("#name").val();
var pwd1 = $("#pwd1").val(); $.post("/Account/DoLogin", { name: name, pwd1: pwd1 },
function (data) {
if (data == "0") {
$("#showLogin").html("登录成功");
window.location.href = "/home/index";
}
else if (data == "-1") {
$("#showLogin").html("用户名或密码为空");
}
else if (data == "-2") {
$("#showLogin").html("用户名或密码错误");
}
});
}

6. AccountController.cs-DoLogin函数:

MVCStudy.Business.User userBll = new Business.User();
public ActionResult DoLogin()
{
//后台c#获取前台js提交过来的数据
string name = Request.Form["name"];
string pwd1 = Request.Form["pwd1"]; int res = ;
if (string.IsNullOrEmpty(name)||string.IsNullOrEmpty(pwd1))
{
res = -;
}
else {
List<MVCStudy.Model.User> userList = userBll.GetModelList("name= '"+name+"' and pwd= '"+pwd1+"'");
if (userList.Count == )
{
res = -;
}
else {
Session["user"] = userList[].Name;
}
} return Content(res.ToString());
}

登录前,先新建一个MVCStudy.Business.User的userBll,利用GetModelList(“查找条件”)找出与输入的name和pwd相同的user,返回的是List<Model>的格式,取出userList[0],即为一条用户的信息,将userList[0].Name存放在Session["user"]中,成功跳转主页后用于显示登录人的信息。

asp.net 完善注册登录+sqlite数据库的更多相关文章

  1. SpringBoot + Vue + ElementUI 实现后台管理系统模板 -- 后端篇(五): 数据表设计、使用 jwt、redis、sms 工具类完善注册登录逻辑

    (1) 相关博文地址: SpringBoot + Vue + ElementUI 实现后台管理系统模板 -- 前端篇(一):搭建基本环境:https://www.cnblogs.com/l-y-h/p ...

  2. ASP.NET会员注册登录模块(MD5加密,Parameters防止SQL注入,判断是否注册)

    MD5加密,Parameters防止SQL注入: protected void btnLog_Click(object sender, EventArgs e)     {         //获取验 ...

  3. php注册登录系统(一)-极简

    序 登录注册系统是日常上网最普通的操作,我设了一个分类一步步完善注册登录系统,若有哪里错误请慧教 所用语言:php 数据库 :mysql 本次实现功能: 1.用户注册 2.用户登录 主要文件: 完整代 ...

  4. Spring Security 的注册登录流程

    Spring Security 的注册登录流程 数据库字段设计 主要数据库字段要有: 用户的 ID 用户名称 联系电话 登录密码(非明文) UserDTO对象 需要一个数据传输对象来将所有注册信息发送 ...

  5. Android Studio 通过一个登录功能介绍SQLite数据库的使用

    前言: SQLite简介:是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且目前已经在 ...

  6. 2014-08-01 ASP.NET中对SQLite数据库的操作——ADO.NET

    今天是在吾索实习的第18天.我主要学习了如何在ASP.NET中对SQLite数据库的操作,其基本操作如下: 添加引用System.Data.SQLite.dll(PS:在网页里面任意找到适合的.NET ...

  7. ASP.net与SQLite数据库通过js和ashx交互(连接和操作)

    ASP.net与SQLite数据库通过js和ashx交互(连接和操作): 废话(也是思路):用的是VS2010,打算做网站前后台.由于不喜欢前台语言里加些与html和css和js的其他内容,想实现前后 ...

  8. nodejs:注册登录session出错以及连接Mongodb数据库时Error connecting to database解决方案

    (1)nodejs:注册登录session出错 解决办法: 在app.js 中将var MongoStore =  require(connect-mongo')改为var MongoStore =  ...

  9. asp.net中配置使用Sqlite轻型数据库

    Sqlite 管理工具 SQLiteDeveloper及破解 功能特点 表结构设计,数据维护,ddl生成,加密数据库支持,sqlite2,3支持 唯一缺憾,收费,有试用期 破解方法: 注册表删除 HK ...

随机推荐

  1. [TCO2013]Block3Checkers

    题意:一个网格上有一些障碍和$3$个在网格边界上的棋子,你要添加一些障碍使得没有两个棋子四连通,问最少添加多少个障碍 官方题解——一张图教你做人... 三个棋子将网格边界分成三段,添加障碍后网格中一定 ...

  2. 20162312 2016-2017-2《Java程序设计》课程总结

    一.每周作业链接汇总 预备作业01 写的是有关老师和学生的关系: 预备作业02 如何做中学: 预备作业03 实验楼学习linux环境: 第一周作业 java入门,虚拟机等课前准备: 第二周作业 掌握J ...

  3. java nio最白话理解

    JAVA NIO是同步非阻塞io.同步和异步说的是消息的通知机制,阻塞非阻塞说的是线程的状态 .下面说说我的理解,client和服务器建立了socket连接:1.同步阻塞io:client在调用rea ...

  4. Xcode no visible @interface for XXX declares

    出现如上面的错误, 是因为没有找到这个方法, 要自己写一个这样的方法 , 如果这是个类目的方法的话,  需要在Target->Linking->Other Linker Flags中添加- ...

  5. [Android Pro] StorageManager简介

    StorageManager StorageManager is the interface to the systems storage service. The storage manager h ...

  6. iOS:基于Socket的第三方框架CocoaAsyncSocket的使用

    CocoaAsyncSocket无疑是目前封装得最完善的Socket库了:支持异步TCP/UDP,支持GCD,Objective-C接口封装,同时还有日志跟踪功能,使用此日志跟踪,程序员可以很方便的进 ...

  7. 在安装python的mysqlclient包时报microsoft visual c++ 14.0 is required的错误

    在安装python的mysqlclient包时报microsoft visual c++ 14.0 is required的错误 pip install mysqlclient 提示报错   解决办法 ...

  8. Activex打包于发布完整版---微软证书制作

    众所周知,Activex组件没有进行有效的签名,在IE上无法安装的,除非你让用户手工开启“接收任何未签名的ActiveX”,这个很明显不现实.而组件签名需要证书,证书从哪里来,你可以选择付1000到3 ...

  9. android简单的答题游戏

    笔者最近开始沦陷于android,从开始入门到现在已经快半个月的时间,于是便写一个较综合,用到了数据库,多线程操作,以及时钟的添加和停止消除,activity之间的动画转换等,适用于初学者学以致用的小 ...

  10. Android-ImageView的属性android:scaleType作用

    在网上查了好多资料,大致都雷同,大家都是互相抄袭的,看着很费劲,不好理解,自己总结一下,留着需要看的话来查找. 代码中的例子如下: <ImageView android:id="@+i ...