精华内容
下载资源
问答
  • Jsp 页面注册与登录实现

    热门讨论 2011-05-18 20:46:07
    页面注册与登录实现 Jsp注册与登录 Jsp注册与登录 Jsp注册与登录
  • GitHub账号注册与登录

    千次阅读 2020-01-02 10:30:08
    GitHub账号注册与登录 一、注册 1、打开官网:https://github.com/login 2、点击“Create your account”,进入GitHub注册页面 3、输入账户名、邮箱地址、密码,点击验证,(注意:账户名、邮箱地址、密码...

    GitHub账号注册与登录

    一、注册

    1、打开官网:https://github.com/login

    2、点击“Create an account”,进入GitHub注册页面

    3、输入账户名、邮箱地址、密码,点击验证,(注意:账户名、邮箱地址、密码必须符合规则,且邮箱地址真实有效

    4、点击:Next:Select a plan

    二、登录

    注册成功后,直接输入注册的账号和密码就可以正常登录了

     

    展开全文
  • c#学习笔记(一)c#注册与登录界面

    万次阅读 多人点赞 2018-11-13 21:28:53
    今天开始写自己的第一篇博客,今天自己想制作一个登录界面。 软件:vs2015 、 sql serve 2017 1、首先打开vs先自己制作一...3、将注册按钮与注册界面相连:(此处效果为点击注册按钮,打开注册界面,隐藏登录界面) ...

    今天开始写自己的第一篇博客,今天自己想制作一个登录界面。


    2020-01-18
    由于之前写的版本问题比较多,所以最近我单独做了一个简单的示例,大家可自行下载查看。此版本在实现上比之前规范,并添加了一些该有的验证。

    链接:https://download.csdn.net/download/qq_38830964/14527281


    软件:vs2015 、 sql serve 2017

    1、首先打开vs先自己制作一个windows窗口应用程序,如下图是笔者自己制作的界面:

    文字在工具栏中选择lable,按钮选择button,文本框选择textbox
    2、此处若有用户名密码则直接输入点击登录,若无则需要点击注册按钮弹出注册窗口。首先我们再创建一个应用窗口:
    我们需要点击注册弹出该窗口
    3、将注册按钮与注册界面相连:(此处效果为点击注册按钮,打开注册界面,隐藏登录界面) private void button2_Click(object sender, EventArgs e) { Register f2 = new Register ();//Register为注册界面的name this.Hide(); f2.Show(); }

    4、同理,当注册完成后,我们应点击确定按钮,回到登录界面。(方法同上)

    5、用户名以及密码的判定问题:

    方法一:将用户名和密码写入本地txt文件中,在注册的时候写入文件,登录的时候从文件中读出信息进行对比,如果文件中有匹配的信息,则可登录成功,若无,则不允许登录;
    方法二:将vs与sql serve数据库相连,将用户名与密码存入数据库中。(两种方法本质思想相同,笔者为了熟悉数据库与vs的联系,采用的是这种方法)
    在菜单栏--工具选项中,有连接到数据库选项,输入自己的服务器名以及自己建的数据库名即可连接。
    

    6、创建数据库:在sql serve中创建自己的数据库,在数据库中新建立表格用于存储用户名和密码,可以简单建立一个表,包含两列,

    CREATE TABLE user ( username nvarchar(20), password varchar(20) )
    7、表建好以后即可在注册界面写入代码将从文本框中获取的用户名及密码写入数据库:

      		if (textBox2.Text == textBox3.Text)
         	   {
                string connectionStr = "Data Source=(服务器名);Initial Catalog=(数据库名);Persist Security Info=True;User ID=(数据库登录账号);Password=(密码); //此处用的调用数据库的方法为sql serve身份验证,若是windows本地验证,则需另外的引用方法
                //创建连接对象
                myConnection = new SqlConnection(connectionStr);
                //测试是否连接成功
                
                // SqlConnection mycon = new SqlConnection(connectionStr); //定义SqlConnection对象实例并连接数据库
               try
                {
                    myConnection.Open();//打开数据库
                }
                catch
                {
                    MessageBox.Show("数据库连接错误", "错误提示");
                }
                finally
               {
                   myConnection.Close();//关闭数据库
               }
    
                username = textBox1.Text.ToString(); //获取用户名 
                
                password = textBox2.Text.ToString(); //获取密码
    
    
                string myinsert = "insert into user(username,password)  select '"+username+"','" +password+ "'";
    
                SqlCommand mycom = new SqlCommand(myinsert, myConnection);       //定义对象并连接数据库
    
                myConnection.Open();//打开数据库
    
                mycom.ExecuteNonQuery();                           //执行插入语句
    
                myConnection.Close();                //关闭对象并释放所占内存空间    
    
              //  myConnection.Dispose();
    
    		 //此处应作判断是否注册成功,此处简略不写
                MessageBox.Show("注册成功,请前往登录界面登录!") ;
    
                Test f2 = new Test();
                this.Close();
                f2.Show();
            }
            else
            {
                MessageBox.Show("两次密码输入不一致,请重新输入!");
            }
        }`
    

    8、所需数据存入数据库后,即可在登录界面登录,登录时需要从数据库中对比输入的用户名密码,若有匹配,则允许登录,反之,不行。代码如下:

    		string username = this.textBox1.Text;
            string password = this.textBox2.Text;
            if (username.Equals("") || password.Equals(""))//用户名或密码为空
            {
                MessageBox.Show("用户名或密码不能为空");
            }
            else//用户名或密码不为空
            {
                string connectionString = "Data Source=服务器名称;Initial Catalog=load;Persist Security Info=True;User ID=sa;Password=此处输入密码";
         myConnection = new SqlConnection(connectionString);
                //测试连接
    
                myConnection.Open(); //打开数据库
    
                string sql = "Select top 1 from user where username='" + username + "' and  password='"+ password + "'";//查找用户sql语句
    
                SqlCommand cmd = new SqlCommand(sql, myConnection);//定义对象并连接数据库
    
                cmd.CommandType = CommandType.Text;
    
                SqlDataReader sdr;
    
                sdr = cmd.ExecuteReader();
    
                if (sdr.Read())         //从结果中找到
                {
                    MainForm f3 = new MainForm ();//MainForm为应用主界面
                    this.Hide();
                    f3.Show();
    
                }
                else
                {
                    MessageBox.Show("用户名或密码错误", "提示");
                    return;
                }
                myConnection.Close();//关闭数据库
            }`
    

    9、用户名密码匹配之后即可允许登录到应用界面。

    参考文章:

    https://blog.csdn.net/weixin_41259130/article/details/81740618

    展开全文
  • PHP 用户注册与登录

    千次阅读 2016-07-29 02:26:20
    网站用户注册与登录是很常用的一个功能,本节教材就以此来演示一下 PHP 中如何开发用户注册与登录模块。 本节需要用到的重点 PHP 基础知识: PHP 中预定义 $_POST 和 $_GET 全局变量来接受用户表单和 URL 参数信息...

    前言

    网站用户注册与登录是很常用的一个功能,本节教材就以此来演示一下 PHP 中如何开发用户注册与登录模块。

    本节需要用到的重点 PHP 基础知识:

    • PHP 中预定义 $_POST 和 $_GET 全局变量来接受用户表单和 URL 参数信息,关于 PHP 表单更多信息参见《PHP 表单》。
    • PHP 正则表达式用于判断用户的输入是否符合要求,关于 正则表达式 更多信息参见《PHP 正则表达式》。
    • 用户登录检测通过后以 session 来保持用户的登录信息,关于 session 更多信息参见《PHP Session》或者《PHP Cookie》。

    需求分析

    主要功能分为 用户注册、用户登录、用户退出、用户中心 四个部分。

    用户注册

    用户注册主要功能有:

    1. 注册信息表单填写界面 javascript 脚本初步检测用户输入的注册信息。
    2. 注册处理模块检测注册信息是否符合要求。
    3. 检测用户名是否已存在。
    4. 将注册信息写入数据表,注册成功。

    用户登录

    用户登录主要功能有:

    1. 登录表单界面 javascript 脚本初步检测用户输入的登录信息。
    2. 登录模块将用户输入信息与数据库数据进行核对。
    3. 登录信息正确,则提示登录成功,将用户设置为登录状态(session)。
    4. 登录信息不正确,则提示登录失败,用户可以再次尝试登录。

    用户退出

    用户退出主要功能有:

    1. 无条件注销 session 。

    用户中心

    用户退出主要功能有:

    1. 判断用户是否登录,如果没有登录,则转向到登录界面。
    2. 如果登录是登录状态,则读出用户相关信息。

    数据表设计

    根据功能需求分析,用于记用户信息的 user 表需要的字段如下:

    字段名 数据类型 说明
    uid mediumint(8) 主键,自动增长
    username char(15) 注册用户名
    password char(32) MD5 加密后的密码
    email varchar(40) 用户 Email
    regdate int(10) 用户注册时间戳

    建表 SQL 参考如下:

    CREATE TABLE `user` (
      `uid` mediumint(8) unsigned NOT NULL auto_increment,
      `username` char(15) NOT NULL default '',
      `password` char(32) NOT NULL default '',
      `email` varchar(40) NOT NULL default '',
      `regdate` int(10) unsigned NOT NULL default '0',
      PRIMARY KEY  (`uid`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

    页面布局

    各页面功能如下:

    • reg.html:用户注册信息填写表单页面
    • conn.php:数据库连接包含文件
    • reg.php:用户注册处理程序
    • login.html:用户登录表单页面
    • login.php:用户登录表单页面
    • my.php:用户中心

    注册页面

    reg.html 负责收集用户填写的注册信息。教程里只列出关键的代码片段,完整的代码附在本节最后。

    注册表单

    <fieldset>
    <legend>用户注册</legend>
    <form name="RegForm" method="post" action="reg.php" onSubmit="return InputCheck(this)">
    <p>
    <label for="username" class="label">用户名:</label>
    <input id="username" name="username" type="text" class="input" />
    <span>(必填,3-15字符长度,支持汉字、字母、数字及_)</span>
    <p/>
    <p>
    <label for="password" class="label">密 码:</label>
    <input id="password" name="password" type="password" class="input" />
    <span>(必填,不得少于6位)</span>
    <p/>
    <p>
    <label for="repass" class="label">重复密码:</label>
    <input id="repass" name="repass" type="password" class="input" />
    <p/>
    <p>
    <label for="email" class="label">电子邮箱:</label>
    <input id="email" name="email" type="text" class="input" />
    <span>(必填)</span>
    <p/>
    <p>
    <input type="submit" name="submit" value="  提交注册  " class="left" />
    </p>
    </form>
    </fieldset>


    javascript 检测代码

    <script language=JavaScript>
    <!--
    
    function InputCheck(RegForm)
    {
      if (RegForm.username.value == "")
      {
        alert("用户名不可为空!");
        RegForm.username.focus();
        return (false);
      }
      if (RegForm.password.value == "")
      {
        alert("必须设定登录密码!");
        RegForm.password.focus();
        return (false);
      }
      if (RegForm.repass.value != RegForm.password.value)
      {
        alert("两次密码不一致!");
        RegForm.repass.focus();
        return (false);
      }
      if (RegForm.email.value == "")
      {
        alert("电子邮箱不可为空!");
        RegForm.email.focus();
        return (false);
      }
    }
    
    //-->
    </script>


    CSS 样式

    <style type="text/css">
        html{font-size:12px;}
        fieldset{width:520px; margin: 0 auto;}
        legend{font-weight:bold; font-size:14px;}
        label{float:left; width:70px; margin-left:10px;}
        .left{margin-left:80px;}
        .input{width:150px;}
        span{color: #666666;}
    </style>

    注册表单效果图:

    注册表单效果图

    数据库连接

    <?php
    $conn = @mysql_connect("localhost","root","root123");
    if (!$conn){
        die("连接数据库失败:" . mysql_error());
    }
    mysql_select_db("test", $conn);
    //字符转换,读库
    mysql_query("set character set 'gbk'");
    //写库
    mysql_query("set names 'gbk'");
    ?>

    注册处理

    reg.php 负责处理用户注册信息。

    注册检测

    if(!isset($_POST['submit'])){
        exit('非法访问!');
    }
    $username = $_POST['username'];
    $password = $_POST['password'];
    $email = $_POST['email'];
    //注册信息判断
    if(!preg_match('/^[\w\x80-\xff]{3,15}$/', $username)){
        exit('错误:用户名不符合规定。<a href="javascript:history.back(-1);">返回</a>');
    }
    if(strlen($password) < 6){
        exit('错误:密码长度不符合规定。<a href="javascript:history.back(-1);">返回</a>');
    }
    if(!preg_match('/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/', $email)){
        exit('错误:电子邮箱格式错误。<a href="javascript:history.back(-1);">返回</a>');
    }


    本段代码首先检测是否 POST 提交访问该页,接下来根据注册要求(用户名 3-15 字符长度,支持汉字、字母、数字及_;密码不得少于 6 位)对用户提交的注册信息进行检测。在检测用户名和电子邮箱时采用了正则检测,关于正则表达式更所信息请参看《PHP 正则表达式》。

    数据库交互

    //包含数据库连接文件
    include('conn.php');
    //检测用户名是否已经存在
    $check_query = mysql_query("select uid from user where username='$username' limit 1");
    if(mysql_fetch_array($check_query)){
        echo '错误:用户名 ',$username,' 已存在。<a href="javascript:history.back(-1);">返回</a>';
        exit;
    }
    //写入数据
    $password = MD5($password);
    $regdate = time();
    $sql = "INSERT INTO user(username,password,email,regdate)VALUES('$username','$password','$email',
    $regdate)";
    if(mysql_query($sql,$conn)){
        exit('用户注册成功!点击此处 <a href="login.html">登录</a>');
    } else {
        echo '抱歉!添加数据失败:',mysql_error(),'<br />';
        echo '点击此处 <a href="javascript:history.back(-1);">返回</a> 重试';
    }

    该段代码首先检测用户名是否已经存在,如果存在则输出提示信息并立即终止程序执行。如果用户名不存在则把注册信息写入数据库,并输出对应提示信息。

    登录页面

    login.html 负责收集用户填写的登录信息。

    <fieldset>
    <legend>用户登录</legend>
    <form name="LoginForm" method="post" action="login.php" onSubmit="return InputCheck(this)">
    <p>
    <label for="username" class="label">用户名:</label>
    <input id="username" name="username" type="text" class="input" />
    <p/>
    <p>
    <label for="password" class="label">密 码:</label>
    <input id="password" name="password" type="password" class="input" />
    <p/>
    <p>
    <input type="submit" name="submit" value="  确 定  " class="left" />
    </p>
    </form>
    </fieldset>

    javascript 检测及 CSS 样式可参考 reg.html,本部分略去,可直接查看最后附录的完整代码。

    登录处理

    login.php 负责处理用户登录与退出动作。

    //登录
    if(!isset($_POST['submit'])){
        exit('非法访问!');
    }
    $username = htmlspecialchars($_POST['username']);
    $password = MD5($_POST['password']);
    
    //包含数据库连接文件
    include('conn.php');
    //检测用户名及密码是否正确
    $check_query = mysql_query("select uid from user where username='$username' and password='$password' limit 1");
    if($result = mysql_fetch_array($check_query)){
        //登录成功
        $_SESSION['username'] = $username;
        $_SESSION['userid'] = $result['uid'];
        echo $username,' 欢迎你!进入 <a href="my.php">用户中心</a><br />';
        echo '点击此处 <a href="login.php?action=logout">注销</a> 登录!<br />';
        exit;
    } else {
        exit('登录失败!点击此处 <a href="javascript:history.back(-1);">返回</a> 重试');
    }

    该段代码首先确认如果是用户登录的话,必须是 POST 动作提交。然后根据用户输入的信息去数据库核对是否正确,如果正确,注册 session 信息,否则提示登录失败,用户可以重试。

    该段代码需要在页面开头启用 session_start() 函数,参见下面 退出处理 代码部分。

    退出处理

    处理用户退出的代码跟处理登录的代码都在 login.php 里。

    session_start();
    
    //注销登录
    if($_GET['action'] == "logout"){
        unset($_SESSION['userid']);
        unset($_SESSION['username']);
        echo '注销登录成功!点击此处 <a href="login.html">登录</a>';
        exit;
    }

    该段代码在处理用户登录的代码之前,只允许以 login.php?action=logout 的方式访问,其他方式都认为是检测用户登录。具体逻辑参看附录完整代码。

    用户中心

    my.php 是用户中心,列在教程里作为用户登录检测参考。

    <?php
    session_start();
    
    //检测是否登录,若没登录则转向登录界面
    if(!isset($_SESSION['userid'])){
        header("Location:login.html");
        exit();
    }
    //包含数据库连接文件
    include('conn.php');
    $userid = $_SESSION['userid'];
    $username = $_SESSION['username'];
    $user_query = mysql_query("select * from user where uid=$userid limit 1");
    $row = mysql_fetch_array($user_query);
    echo '用户信息:<br />';
    echo '用户ID:',$userid,'<br />';
    echo '用户名:',$username,'<br />';
    echo '邮箱:',$row<'email'>,'<br />';
    echo '注册日期:',date("Y-m-d", $row['regdate']),'<br />';
    echo '<a href="login.php?action=logout">注销</a> 登录<br />';
    ?>

    提示

    1. 用户注册登录涉及到用户信息与数据库的交互,因此要特别注意用户提交的信息不能为非法信息,本例中注册部分已经使用正则表达式做了限制,对登录部分只简单使用了 htmlspecialchars() 处理,实际应用时可更严格一些。
    2. 本教程只是简单演示用户注册与登录的过程,其代码仅供学习参考,不可直接用于项目生产。
    3. 本教程中对于用户登录成功后采用 session 来管理,也可以采用 cookie 来管理,尤其对于有时限要求的情况。
    4. 为了提高用户体验,用户注册部分可以结合 AJAX 来检测用户输入的信息而不必等点击提交后再检测。

    以下列出了用户注册与登录的完整代码

    login.html

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
    <title>用户登录</title>
    <style type="text/css">
        html{font-size:12px;}
        fieldset{width:520px; margin: 0 auto;}
        legend{font-weight:bold; font-size:14px;}
        label{float:left; width:70px; margin-left:10px;}
        .left{margin-left:80px;}
        .input{width:150px;}
        span{color: #666666;}
    </style>
    <script language=JavaScript>
    <!--
    
    function InputCheck(LoginForm)
    {
      if (LoginForm.username.value == "")
      {
        alert("请输入用户名!");
        LoginForm.username.focus();
        return (false);
      }
      if (LoginForm.password.value == "")
      {
        alert("请输入密码!");
        LoginForm.password.focus();
        return (false);
      }
    }
    
    //-->
    </script>
    </head>
    <body>
    <div>
    <fieldset>
    <legend>用户登录</legend>
    <form name="LoginForm" method="post" action="login.php" onSubmit="return InputCheck(this)">
    <p>
    <label for="username" class="label">用户名:</label>
    <input id="username" name="username" type="text" class="input" />
    <p/>
    <p>
    <label for="password" class="label">密 码:</label>
    <input id="password" name="password" type="password" class="input" />
    <p/>
    <p>
    <input type="submit" name="submit" value="  确 定  " class="left" />
    </p>
    </form>
    </fieldset>
    </div>
    </body>
    </html>

    conn.php

    <?php
    /*****************************
    *数据库连接
    *****************************/
    $conn = @mysql_connect("localhost","root","root123");
    if (!$conn){
        die("连接数据库失败:" . mysql_error());
    }
    mysql_select_db("test", $conn);
    //字符转换,读库
    mysql_query("set character set 'gbk'");
    //写库
    mysql_query("set names 'gbk'");
    ?>


    reg.php

    <?php
    if(!isset($_POST['submit'])){
        exit('非法访问!');
    }
    $username = $_POST['username'];
    $password = $_POST['password'];
    $email = $_POST['email'];
    //注册信息判断
    if(!preg_match('/^[\w\x80-\xff]{3,15}$/', $username)){
        exit('错误:用户名不符合规定。<a href="javascript:history.back(-1);">返回</a>');
    }
    if(strlen($password) < 6){
        exit('错误:密码长度不符合规定。<a href="javascript:history.back(-1);">返回</a>');
    }
    if(!preg_match('/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/', $email)){
        exit('错误:电子邮箱格式错误。<a href="javascript:history.back(-1);">返回</a>');
    }
    //包含数据库连接文件
    include('conn.php');
    //检测用户名是否已经存在
    $check_query = mysql_query("select uid from user where username='$username' limit 1");
    if(mysql_fetch_array($check_query)){
        echo '错误:用户名 ',$username,' 已存在。<a href="javascript:history.back(-1);">返回</a>';
        exit;
    }
    //写入数据
    $password = MD5($password);
    $regdate = time();
    $sql = "INSERT INTO user(username,password,email,regdate)VALUES('$username','$password','$email',
    $regdate)";
    if(mysql_query($sql,$conn)){
        exit('用户注册成功!点击此处 <a href="login.html">登录</a>');
    } else {
        echo '抱歉!添加数据失败:',mysql_error(),'<br />';
        echo '点击此处 <a href="javascript:history.back(-1);">返回</a> 重试';
    }
    ?>


    login.html

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
    <title>用户登录</title>
    <style type="text/css">
        html{font-size:12px;}
        fieldset{width:300px; margin: 0 auto;}
        legend{font-weight:bold; font-size:14px;}
        .label{float:left; width:70px; margin-left:10px;}
        .left{margin-left:80px;}
        .input{width:150px;}
        span{color: #666666;}
    </style>
    <script language=JavaScript>
    <!--
    
    function InputCheck(LoginForm)
    {
      if (LoginForm.username.value == "")
      {
        alert("请输入用户名!");
        LoginForm.username.focus();
        return (false);
      }
      if (LoginForm.password.value == "")
      {
        alert("请输入密码!");
        LoginForm.password.focus();
        return (false);
      }
    }
    
    //-->
    </script>
    </head>
    <body>
    <div>
    <fieldset>
    <legend>用户登录</legend>
    <form name="LoginForm" method="post" action="login.php" onSubmit="return InputCheck(this)">
    <p>
    <label for="username" class="label">用户名:</label>
    <input id="username" name="username" type="text" class="input" />
    <p/>
    <p>
    <label for="password" class="label">密 码:</label>
    <input id="password" name="password" type="password" class="input" />
    <p/>
    <p>
    <input type="submit" name="submit" value="  确 定  " class="left" />
    </p>
    </form>
    </fieldset>
    </div>
    </body>
    </html>

    login.php

    <?php
    session_start();
    
    //注销登录
    if($_GET['action'] == "logout"){
        unset($_SESSION['userid']);
        unset($_SESSION['username']);
        echo '注销登录成功!点击此处 <a href="login.html">登录</a>';
        exit;
    }
    
    //登录
    if(!isset($_POST['submit'])){
        exit('非法访问!');
    }
    $username = htmlspecialchars($_POST['username']);
    $password = MD5($_POST['password']);
    
    //包含数据库连接文件
    include('conn.php');
    //检测用户名及密码是否正确
    $check_query = mysql_query("select uid from user where username='$username' and password='$password' 
    limit 1");
    if($result = mysql_fetch_array($check_query)){
        //登录成功
        $_SESSION['username'] = $username;
        $_SESSION['userid'] = $result['uid'];
        echo $username,' 欢迎你!进入 <a href="my.php">用户中心</a><br />';
        echo '点击此处 <a href="login.php?action=logout">注销</a> 登录!<br />';
        exit;
    } else {
        exit('登录失败!点击此处 <a href="javascript:history.back(-1);">返回</a> 重试');
    }
    ?>

    my.php

    <?php
    session_start();
    
    //检测是否登录,若没登录则转向登录界面
    if(!isset($_SESSION['userid'])){
        header("Location:login.html");
        exit();
    }
    
    //包含数据库连接文件
    include('conn.php');
    $userid = $_SESSION['userid'];
    $username = $_SESSION['username'];
    $user_query = mysql_query("select * from user where uid=$userid limit 1");
    $row = mysql_fetch_array($user_query);
    echo '用户信息:<br />';
    echo '用户ID:',$userid,'<br />';
    echo '用户名:',$username,'<br />';
    echo '邮箱:',$row['email'],'<br />';
    echo '注册日期:',date("Y-m-d", $row['regdate']),'<br />';
    echo '<a href="login.php?action=logout">注销</a> 登录<br />';
    ?>


    转载自:http://www.5idev.com/p-php_user_reg_login_code.shtml





    展开全文
  • 总的来说就是首先进行数据库的设计,然后根据数据库进行编写服务端API接口,接着来到客户端或移动端,进行登录与注册的界面设计,接收服务端提供的数据并显示在界面上。本文章主要进行后端API接口设计。后面会进行...

    这次实现的注册与登录功能需要进行数据库的基本操作,而且是前后端分离式开发。总的来说就是首先进行数据库的设计,然后根据数据库进行编写服务端API接口,接着来到客户端移动端,进行登录与注册的界面设计,接收服务端提供的数据并显示在界面上。本文章主要进行后端API接口设计。后面会进行前端框架数据交互设计。


    一、数据库设计

    根据一般登录与注册的需求,数据库的用户表结构如下:

    在这里插入图片描述

    二、服务端API接口设计

    1、首先进行持久化映射,生成用户表的模型类

    (1)、找到Persistence一栏,选中项目,鼠标右键,点击最底下一个选项。

    在这里插入图片描述

    (2)、选择模型类的位置,选中用户表的所有字段,点击OK。

    在这里插入图片描述

    (3)、找到生成的模型类Users,添加主键生成器。在注解@Id下方添加以下代码:

    //指定生成器名称
    @GeneratedValue(generator = "uuid2" )
    @GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator" )
    

    2、创建DAO层,新建接口类UsersDao。代码如下:

    package edu.ynmd.cms.dao;
    import edu.ynmd.cms.model.Users;
    import org.springframework.data.jpa.repository.JpaRepository;
    import org.springframework.data.jpa.repository.Query;
    import org.springframework.data.repository.query.Param;
    import java.util.List;
    
    public interface UsersDao extends JpaRepository<Users,String> {
    
        @Query("select u from Users u where u.username=:username and u.pass=:pass")
        List<Users> getUsersByUsernameAndPass(@Param("username")String username, @Param("pass") String pass);
        
    }
    

    3、编写server

    (1)、ManageService里面进行增删查改方法的定义。

        //用户表
        Users saveUser(Users users);
        boolean deleteUser(String id);
        Users getUser(String id);
        Users getUserByUserNameAndPass(String username,String pass);
    

    (2)、MangeServiceImpl里面进行具体方法的实现。

    //*****************************用户表增删查改开始*********************************
        @Override
        public Users saveUser(Users users) {
            try {
                return usersDao.save(users);
            } catch (Exception e) {
                e.printStackTrace();
                return null;
            }
        }
    
        @Override
        public boolean deleteUser(String id) {
            try {
                usersDao.deleteById(id);
                return true;
            } catch (Exception e) {
                e.printStackTrace();
            }
    
            return false;
        }
    
        @Override
        public Users getUser(String id) {
            Optional<Users> temp=usersDao.findById(id);
            return temp.isPresent()?temp.get():null;
        }
    
        @Override
        public Users getUserByUserNameAndPass(String username, String pass) {
            List<Users> ul=usersDao.getUsersByUsernameAndPass(username,pass);
            if(ul.size()>0){
                return ul.get(0);
            }
            return null;
        }
    

    4、来到PublicAction,编写API接口

    //用户登录方法
        @PostMapping("/login")
        @ResponseBody
        public HashMap<String,String> login(
                @RequestBody Account account) throws IOException {
            Users u=manageService.getUserByUserNameAndPass(account.username,account.password); //获取用户表的用户名和密码
            if(u!=null){
                String jwt= JwtUtil.generateToken(u.getRoleid(),u.getUsersid());  //获取用户角色和用户ID
    
                return new HashMap<String,String>(){{
                    put("msg","ok");
                    put("token",jwt);
                    put("role",u.getRoleid());
                    // put("role","admin");
                }};
            }
            else {
                return new HashMap<String,String>(){{
                    put("msg","error");
                    put("token","error");
                }};
            }
        }
    
        public static class Account{
            public String username;
            public String password;
        }
    
        //用户注册
        @PostMapping("saveUser")
        @ResponseBody
        public HashMap saveUser(@RequestBody Users users) throws Exception{
            HashMap m=new HashMap();
    
            try {
                users.setRoleid("member");
    
                manageService.saveUser(users);
                m.put("msg","ok");
            } catch (Exception e) {
                e.printStackTrace();
    
                m.put("msg","error");
            }
    
    
            return m;
        }
    

    最后,启动项目进行测试。

    三、使用postman进行注册与登录测试

    1、postman注册测试

    image

    2、查看数据库内容,可以看到刚刚已经注册成功

    在这里插入图片描述

    3、postman登录测试

    在这里插入图片描述

    4、输入一个错误密码,测试能不能登录

    在这里插入图片描述

    到此,服务端API接口已经实现,后面会写关于客户端和移动端与API接口进行数据交互的文章,敬请期待!
    展开全文
  • 网上很多Django关于实现用户注册与登录的教程都是用Django 1.X写的,比较老了,所以小编我觉得有必要亲自动手用Django 2.0重写用户注册与登陆教程。另外网上很多教程忽略了Django Auth模块自带的User模型而重新建立...
  • 我想用C++面向对象的方法用户注册与登录,我定义了用户类,然后定义了两个成员函数用于注册与登录,但我不知到在主函数调用这两个方法时函数的实参表该如何填,应为要从键盘输入后才知道是哪些参数 下面是主函数代码...
  • 用户注册与登录功能是普遍App常见且基础的功能之一。 下面我们结合服务端和App 实现用户注册与登录功能。业务基本需求1、手机号码密码登录 2、手机短信(或语音)验证码快速登录(从未登录过则自动生成用户账号...
  • 用户注册与登录构造图

    千次阅读 2017-06-09 16:34:40
    注册登录
  • shiro的用户加密注册与登录

    千次阅读 2019-01-08 19:47:58
    写在前边 现在的时间:2018-1-8 (离数据库考试还有2天,我的心是真滴大。...我相信你对shiro不加密的用户注册与加密已经有了了解。 如果是这样的话那么你只需要下面这个shiro提供的加密函数 Stri...
  • Beego 简单用户注册与登录

    千次阅读 2019-05-24 16:25:40
    // 实际情况注册成功返回到登录页面 this.Redirect("login", 302) } type LoginController struct { beego.Controller } // 登录页面 get func (this *LoginController) ShowLogin() { this.TplName = "login...
  • 利用struts2框架连接数据库实现用户注册与登录 工具/原料 eclipse、struts-2.3.16.3 Mysql 方法/步骤 1 工程目录: 工程用到的...
  • 用户注册与登录功能的实现

    千次阅读 2017-08-01 10:52:24
    运用firebase集成了用户登录与注册的功能
  • php实例——用户注册与登录

    千次阅读 2016-11-18 21:48:35
    这周做了个php的简单实例,算是学了这么久php语法的一次综合应用吧,感觉前面学的东西都不知道怎么用,不看教程还真做不出来...首先这个实例包括六个文件,用户登录两个(login.html,login.php)、用户注册两个(reg.
  • 【discuz x3】注册与登录

    千次阅读 2014-01-08 09:41:25
    一、注册: 二、登录
  • 登录与注册 打开localhost:8080链接,进入kb-dms数据库管理平台首页 页面自动跳转到登录页面 点击登录框,右上角的按钮,页面跳转到注册页面 注册成功后,页面自动跳转到登录页面 输入注册的账号密码,点击回车键...
  • Jsp页面注册与登录

    万次阅读 2012-12-06 21:29:20
    用户信息的bean: package chen; public class UserBean ... //设置待注册的用户信息。... //进行注册 ...提交注册数据进入数据库: ...登录成功,欢迎您! </h1><%=trans(session.getAttribute("userid1"))%>
  • 本人对初次接触java ee,感觉这个简单的m删除文字格式vc实现的用户登录与注册比较的有参照价值。故记录下来。本篇中的代码源自于《轻量级Java EE企业应用实战(第三版)》第二章,其原来的代码是实现用户登录,我在...
  • 添加注册页面 1.1 找到添加用户界面,并将该界面的网站地址复制下来(http://alvincr.com/wp-admin/user-new.php) 1.2 在主页上新建一个页面用于管理注册窗口 这样登录首页便能看到已经添加用户注册的窗口 1.3 添加...
  • from os import path from uuid import uuid4 from flask import flash, url_for, redirect, render_template, Blueprint from jmilkfansblog.forms import LoginForm, RegisterForm from jmilkfansblog.models ...
  • 用户登录注册流程图 老版: 新版: 登陆界面 注册界面 登陆成功界面 LoginServlet import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.annotation.Web...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 482,400
精华内容 192,960
关键字:

注册与登录