设为首页 收藏本站
查看: 691|回复: 0

[经验分享] PHP学习笔记<2>

[复制链接]

尚未签到

发表于 2017-3-22 10:27:12 | 显示全部楼层 |阅读模式

PHP的数据库操作.( MySQL)


先看看我们在jsp中怎么连接数据库的?
其实我们都是在servlet中才连接数据库的, 也就是在jsp中动态显示数据, 而在servlet中后台处理数据, 即数据库的操作是放在servlet中的. 这样可达到数据与页面分离的效果, 更易于维护修改, 也是MVC模式的一大好处吧.
举个最简单的例子, 大家都写过的登陆页面:


【一】jsp + servlet 的方法:


login.html 登陆页面

 


<h1>用户登录</h1>
<form action="checkLogin" method="POST">
用户名:<input type= "text" name= "username"/><br>
密 码 :<input type="password" name="userpwd"/><br>
<input type="submit" value="登录"/>
</form>

 我们写了个login.html 得到用户输入的用户名和密码, 然后我们需要一个checkLogin的servlet 来验证用户, 此时servlet 就要到数据库中通过用户名和密码查询是否有该用户, 判断之后再进行页面转发.
 
CheckLogin.java (这是一个servlet. 这里只列出了其中的数据处理部分)
 

// 得到输入的 用户名 和密码
String username = request.getParameter("username");
String userpwd = request.getParameter("userpwd");
Userinfo user = UserDao.checkUserLogin(username, userpwd);
if (user != null) { // 如果用户验证成功~~转发到 loginOK.jsp 页面 显示
request.getRequestDispatcher("loginOK.jsp").forward(request,
response);
} else { //如果登录失败
request.getRequestDispatcher("loginFaile.jsp").forward(request, response);
}

        在这里面有个checkUserLogin的方法, 在是User 的DAO类中的一个方法. 我们在User的DAO中, 连接数据库, 执行sql查询, 返回User对象.
然后在配置文件中,添加servlet的配置

 


  <servlet>
<servlet-name>check</servlet-name>
<servlet-class>servlet.checkLogin</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>check</servlet-name>
<url-pattern>/checkLogin</url-pattern>
</servlet-mapping>

 
基本的流程是这样的: 


DSC0000.png




 【二】php 的方法:


再来看看PHP连接MySQL, 在php中直接访问数据库是相当简便的.
在jsp中, 我们把数据发给后台servlet处理, 而php虽然也是发给后台处理, 只不过后台也是php ---- 没有html的php 代码.
这个是大概的流程:
 
DSC0001.png
 
 
 
 
 
 
 
 
 
 
login.html 页面就一样了, 只是有个地方要小改, 即<form>里面action="checkLogin"
要改成action="checkLogin.php"
 
checkLogin.php
 

<?php
//得到数据库连接
require_once('conn.php');
//得到post中传来的参数
$username = $_POST['username'];
$password = $_POST['userpwd'];
$sql = "select * from userinfo where username = '" .$username. "' and userpwd = '" .$password. "'";
echo $sql;
$rs = mysql_query($sql) or die ('查询出错了..');   //执行sql语句,
while($row = mysql_fetch_array($rs)){
echo "<br />";
echo '登陆成功';
echo '用户名:'.$row['username'] . "   密码: " . $row['userpwd'];
}
mysql_close($conn);
?>

       其中conn.php, 是负责数据库连接的页面, 这相当于jsp的页面重用技术,减少代码了的同时,又方便维护。
 
conn.php
 

<?php
//用来处理连接到数据库的php
#获得数据库连接
$conn = mysql_connect('localhost','root','netjava');
if(!$conn){
die('数据库连接失败!'); #退出.
}
#选择要使用的数据库
$t = mysql_select_db('myblog',$conn);
if(!$t){
die('没有这个数据库!');
}
?>

  
 
 
到现在已经很清楚了。。
这样理解不知道妥不妥
php = jsp + servlet;
暂时这样理解吧。
 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-353480-1-1.html 上篇帖子: PHP中的单引号 下篇帖子: PHP在线压缩/解压程序
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表