【小小白】简单实现网页登录(HTML+CSS+PHP)

环境配置

1、PHPstorm(不建议升级最新版,每次都会提醒输入密钥,超烦人!)
2、MySQL8.0
3、Navicat 15 for mysql
4、phpstudy也很好用
参考配置:https://blog.csdn.net/weixin_46336128/article/details/106496405(这篇博客讲的很详细,强推!)

一、前端:模仿B站上的写的

https://www.bilibili.com/video/BV1ta4y1W7wu

1.HTML:

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<link rel="stylesheet" href="style.css" />
	<link rel="stylesheet" href="iconfont.css" />  <!--插入图标的文件-->
	<title>Login</title>
</head>
<body>
<form action="1.php" method="post">
	<div id="bigBox">
		<h1>LOGIN</h1>
		<div class="inputBox">
			<div class="inputText">
				<span class="iconfont icon-nickname"></span>  <!--图标的插入,相应网站上有它的格式-->
				<input type="text"  name="username" placeholder="Username" /> <!--input插入输入?-->
			</div>
			<div class="inputText">
				<span class="iconfont icon-visible"></span>
				<input type="password"  name="password"  placeholder="Password" />
			</div>
		</div>
		<input class="loginButton" type="submit" name="login" value="Login"/>
	</div>
</form>
</body>
</html>

2.CSS:

body
{
	margin: 0;
	padding: 0;
	background-image: url(begin.jpg);	/* 背景图片 */
	background-repeat: no-repeat;	/* 背景图片不重复 */
}

#bigBox
{
	margin: 0 auto;	/* login框剧中 */
	margin-top: 200px; /* login框与顶部的距离 */
	padding: 20px 50px;	/* login框内部的距离(内部与输入框和按钮的距离) */
	background-color: #00000090;	/* login框背景颜色和透明度 */
	width: 400px;
	height: 300px;
	border-radius: 10px;	/* 圆角边 */
	text-align: center;	/* 框内所有内容剧中 */
}

#bigBox h1
{
	color: white;	/* LOGIN字体颜色 */
}

#bigBox .inputBox
{
	margin-top: 50px;	/* 输入框顶部与LOGIN标题的间距 */
}

#bigBox .inputBox .inputText
{
	margin-top: 20px;	/* 输入框之间的距离 */
}

#bigBox .inputBox .inputText
{
	color: white;	/*图标的颜色  */
}

#bigBox .inputBox .inputText input
{
	border: 0;	/* 删除输入框边框 */
	padding: 10px 10px;	/* 输入框内的间距 */
	border-bottom: 1px solid white;	/* 输入框白色下划线 */
	background-color: #00000000;	/* 输入框透明 */
	color: white;	/* 输入字体的颜色 */
}

#bigBox .loginButton
{
	margin-top: 30px;	/* 按钮顶部与输入框的距离 */
	width: 150px;
	height: 25px;
	color: white;	
	border: 0; /* 删除按钮边框 */
	border-radius: 20px;	/* 按钮圆角边 */
	background-image: linear-gradient(to right, #b8cbb8 0%, #b8cbb8 0%, #b465da 0%, #cf6cc9 33%, #ee609c 66%, #ee609c 100%);	/* 按钮颜色 */
}
a
{
color: white;
}

强调:这几个文件要放在同一目录下,且放在phpstudy的www文件里面

3.效果图:

在这里插入图片描述

二、后端:推荐上菜鸟教程学习PHP语法,特别要注意使用的PHP版本,之前 因为没有注意PHP的版本问题,花了很多时间纠结

1.数据库的建立

(1)配置好mysql后先通过cmd打开服务,注意一定要以管理员的身份打开!!!而且要在mysql安装的磁盘下执行命令(cd即可)

net start mysql

在这里插入图片描述
(2)打开mysql服务后打开Navicat,创建新的数据库,创建的数据库名字最好为英文

点击左上角的连接即可创建新的数据库
在这里插入图片描述

在这里插入图片描述
新建一个表
在这里插入图片描述
在这里插入图片描述

2.PHP文件

<?php
$username='root';
$password='   ';
$host='localhost';
$database='wangye';
//创建连接
$conn=mysqli_connect($host,$username,$password,$database);
if (mysqli_connect_errno())
{
    echo "连接失败: " . mysqli_connect_error();
}else {
    echo "连接成功<br>";
}
$name=$_POST['username'];
$pwd=$_POST['password'];
$qury=mysqli_query($conn,"select id from  login where username='$name' and password='$pwd' ");//查询数据库
$result=mysqli_num_rows($qury);//返回行数
if ($result==0){
    echo "登录失败!";
}else{
    echo  "登录成功!";
}
?>

一定要注意自己写的PHP版本,PHP6.0以上的函数基本都是mysqli,基本舍弃了mysql的用法,有些函数也不能用了

3.实现效果:实现基本的登录,这里就没有做跳转的网页了

在这里插入图片描述
在这里插入图片描述

总结:

1、在学习的过程中因为我用的是PHP7.0,没有详细规范的总结所以学习的很难受
2、最后写PHP文件的时候经常把字母打错,以致浪费了很多时间检查问题,吐血!

  • 8
    点赞
  • 50
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
好的,我给你提供一份简单的示例代码,你可以根据自己的需要进行修改。首先是 HTML 文件: ```html <!DOCTYPE html> <html> <head> <title>Login</title> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> </head> <body> <h1>Login</h1> <form> <label for="username">Username:</label> <input type="text" id="username" name="username"><br><br> <label for="password">Password:</label> <input type="password" id="password" name="password"><br><br> <input type="button" id="submit" value="Submit"> </form> <script> $(document).ready(function() { $("#submit").click(function() { var username = $("#username").val(); var password = $("#password").val(); $.ajax({ url: "/login", type: "POST", data: { username: username, password: password }, success: function(response) { if (response == "success") { window.location.href = "/dashboard"; } else { alert("Invalid username or password."); } }, error: function() { alert("Error occurred."); } }); }); }); </script> </body> </html> ``` 这个 HTML 文件包含了一个表单,用户输入用户名和密码,点击 Submit 按钮后会触发一个 AJAX 请求,将用户名和密码发送到后端进行验证。 接下来是 Flask 后端的代码: ```python from flask import Flask, render_template, request, session, redirect, url_for app = Flask(__name__) app.secret_key = "your_secret_key" @app.route("/") def index(): return render_template("login.html") @app.route("/login", methods=["POST"]) def login(): username = request.form["username"] password = request.form["password"] # 在这里进行用户名和密码的验证,可以连接数据库或者使用其他方式进行验证 if username == "admin" and password == "123456": session["username"] = username return "success" else: return "failure" @app.route("/dashboard") def dashboard(): if "username" in session: return "Welcome, " + session["username"] + "!" else: return redirect(url_for("index")) @app.route("/logout") def logout(): session.pop("username", None) return redirect(url_for("index")) if __name__ == "__main__": app.run(debug=True) ``` 这个 Flask 应用包含了三个路由: - `/`:渲染登录页面的路由。 - `/login`:接收 AJAX 请求的路由,进行用户名和密码的验证。 - `/dashboard`:展示用户登录后的页面。 在这个示例中,我们使用 Flask 的 session 来保存用户的登录状态。如果用户成功登录,我们将用户的用户名保存在 session 中,然后跳转到 `/dashboard` 路由,展示欢迎页面。如果用户访问 `/dashboard` 路由但是没有登录,我们将会重定向到登录页面。如果用户访问 `/logout` 路由,我们将会清除 session 中的用户名,然后重定向到登录页面。 注意,在实际应用中,我们需要使用更安全的方式进行密码验证,例如使用哈希加盐算法等。此外,在这个示例中,我们使用了简单的页面重定向和 alert 弹框来展示消息,但是在实际应用中,我们可能需要使用更好的用户体验方式来展示消息,例如使用 toastr 或者使用 Bootstrap 的模态框。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值