声明:本程序纯粹是本人在学习过程中突发奇想做的,并未考虑任何可行性,实用性,只是留下来供以后参考。

前端页面

sign.html

<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8'>
<title>QQ注册&登录</title>
<link rel='stylesheet' type='text/css' href='./sign.css'>
<script src="http://cdn.bootcss.com/blueimp-md5/1.1.0/js/md5.js"></script>
<script src='./sign.js' type='text/javascript'> </script>
</head>
<body>
<div class='header'>QQ注册&登录</div>
<div class='container'>
<h3>注册</h3>
<form name='signup' action='./signup.php' onsubmit='return validateForm1()' method='post'>
QQ:<input type='text' name='uid' id='userid1'>
密码:<input type='password' name='upd' id='userpassword1'>
<input type='submit' onsubmit="" value='注册'>
</form>
<h3>登录</h3>
<form name='signin' action='./signin.php' onsubmit='return validateForm2();' method='post'>
QQ:<input type='text' name='uid' id='userid2'>
密码:<input type='password' name='upd' id='userpassword2'>
<input type='submit' onsubmit="" value='登录'>
</form>
</div>
</body>
</html>

CSS

sign.css

* {
margin: 0 0 0 0;
padding: 0 0 0 0;
} body {
background:whitesmoke;
font-size: 1em;
}
.header {
height:3em;
font-size: 2.5em;
line-height: 3em;
color:gray;
border-bottom:solid black 1px;
text-align: center;
}
.container {
text-align: center;
}

JS

sign.js

function validateForm1(){
var id = this['userid1'].value;
var password = this['userpassword1'].value;
if ( !id.match(/^\d{5,10}$/) ) {
alert ('ID必须为5至10位数字');
return false;
}
if ( !password.match(/^[\d\w]{6,18}$/) ) {
alert ('密码必须为6至32位数字和(或)字母');
return false;
}
this['userpassword1'].value = md5(password);
} function validateForm2(){
var id = this['userid2'].value;
var password = this['userpassword2'].value;
if ( !id.match(/^\d{5,10}$/) ) {
alert ('ID必须为5至10位数字');
return false;
}
if ( !password.match(/^[\d\w]{6,18}$/) ) {
alert ('密码必须为6至18位数字和(或)字母');
return false;
}
this['userpassword2'].value = md5(password);
}

服务器端脚本

signin.php

<?php
$uid = $_POST['uid'];
$upd = $_POST['upd']; $upd = md5($upd); $conn = mysqli_connect('localhost', 'myqq', 'myqq', 'qq');
if (!$conn)
{
die ("数据库连接失败" . mysqli_connect_error());
} $sql_select = <<<EOF
select id,password from user where id = '$uid'
EOF;
$result = $conn->query($sql_select);
if ( $result->num_rows == 1){
//echo '用户存在';
$dbupd = ($result->fetch_assoc())['password'];
if ( $dbupd == $upd ){
echo "登录成功";
}
else {
echo "密码错误";
//echo "<br>" . $upd . "<br>" . $dbupd;
} }
else {
echo "用户不存在";
}
?>

signup.php

<?php
$uid = $_POST['uid'];
$upd = $_POST['upd']; $upd = md5($upd);
//echo $upd . '<br>';
//echo $uid . $upd;
$conn = mysqli_connect( 'localhost', 'myqq', 'myqq', 'qq' );
if (!$conn){
die ("数据库连接失败" . mysqli_connect_error() );
} $sql_select = <<<EOF
select id,password from user where id = '$uid'
EOF;
//echo $sql_select;
$result = $conn->query( $sql_select ) ;
if ( $result->num_rows <= 0){
$sql_insert = <<<EOF
insert into user values($uid, '$upd')
EOF;
if ( $conn->query($sql_insert) === TRUE )
{
echo '注册成功';
}
else {
echo "注册失败,请重试" . $sql . '<br>' . $conn->error;
}
}
else {
echo "用户已存在";
}
$conn-close();
?>

最新文章

  1. 【从零开始学BPM,Day1】工作流管理平台架构学习
  2. 什么是SARG ?
  3. Java Eclipse解决中文字体太小
  4. Js分页插件,支持页面跳转
  5. List与Set的使用
  6. vim中大小写转化
  7. 使用 getopt() 进行命令行处理
  8. XLSTransformer生成excel文件简单演示样例
  9. JSP table中除了第一行(标题)其他全清空
  10. Javascript面向对象编程(一):封装
  11. Python 函数和相关用法笔记
  12. Arrays类的运用,二分法,数组的复制,命令行参数的运用,二维数组,Object,equals
  13. android 第三次作业
  14. Python_day9
  15. 一台电脑安装两个JDK
  16. 根据框架的dtd或xsd生成xml文件
  17. 去除swagger ui的红色 error 错误提示
  18. Arduino IDE for ESP8266教程(二) 创建WIFI AP模式
  19. oauth2.0学习笔记(摘抄简化)
  20. 洛谷 P4284 [SHOI2014]概率充电器 解题报告

热门文章

  1. urllib基本用法(了解)
  2. git branch stash
  3. 开发工具篇:Git和Github
  4. 浅谈JS异步(asychrouous)
  5. GIMP(Linux下的Photoshop),Centos7下安装过程
  6. 上线前一个小时,dubbo这个问题可把我折腾惨了
  7. httpClient爬虫
  8. YYC松鼠短视频系统上传视频会被压缩的问题如何解决?
  9. 二、Django学习之增删改查
  10. 仅主机、NAT、桥接模式