【使用jdbc和servlet实现阅览文章访问次数】
2015-06-10 15:17
477 查看
Java代码
package com.lm.org;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class Test
*/
public class Test extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
*/
public Test() {
super();
}
/**
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
/**
*/
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
//HttpSession session = request.getSession();// 得到session
//ServletContext application = super.getServletContext();
//Integer accessCount = (Integer) application.getAttribute("accessCount");//数据库查询出来
Integer wiewsCount=null;
Connection connection = null;
String sql="select * from t_news where id=1 ";//wiewsCount
PreparedStatement ps=null;
ResultSet rs=null;
try {
connection=getConnection();
ps = connection.prepareStatement(sql);
rs = ps.executeQuery();
if(rs.next()){
wiewsCount = rs.getInt("wiewsCount");
if(wiewsCount==null){
wiewsCount = 1;
}else{
wiewsCount = wiewsCount + 1;
Connection cn =getConnection();
String sql1="update t_news set wiewsCount="+wiewsCount+" where id=1";
PreparedStatement prepareStatement = cn.prepareStatement(sql1);
int executeUpdate = prepareStatement.executeUpdate();
if(executeUpdate>0){
System.out.println("1");
}else{
System.out.println(2);
}
cn.close();
cn=null;
prepareStatement.close();
prepareStatement=null;
}
}
} catch (SQLException e) {
e.printStackTrace();
}finally{
try {
connection.close();
connection=null;
ps.close();
ps=null;
rs.close();
rs=null;
} catch (SQLException e) {
e.printStackTrace();
}
}
Integer ac;
try {
ac = accessCount(request, response);
out.println("模拟值="+ac+"\t数据库值="+wiewsCount);
} catch (Exception e) {
e.printStackTrace();
}
out.flush();
out.close();
}
public static Integer accessCount(HttpServletRequest request,HttpServletResponse response)throws Exception{
HttpServletRequest hs=(HttpServletRequest)request;
ServletContext application = hs.getServletContext();
Integer accessCount = (Integer) application.getAttribute("accessCount");//数据库查询出来
//if=null
if (accessCount == null) {
accessCount = 1;
application.setAttribute("accessCount", accessCount);
} else {
//else +1并修改数据库的值
accessCount = accessCount + 1;
application.setAttribute("accessCount", accessCount);
//update
}
return accessCount;
}
/**
* @return
*/
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName(Driver);
conn = DriverManager.getConnection(Url, UserName, PassWord);
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
private static String Driver = "com.mysql.jdbc.Driver";// ConfigUtils.getProperty("jdbc.driver");
private static String Url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8";// ConfigUtils.getProperty("jdbc.url");
private static String UserName = "root";// ConfigUtils.getProperty("jdbc.userName");
private static String PassWord = "root";// ConfigUtils.getProperty("jdbc.passWord");
}
package com.lm.org;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
* Servlet implementation class Test
*/
public class Test extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
*/
public Test() {
super();
}
/**
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
/**
*/
protected void doPost(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
PrintWriter out = response.getWriter();
//HttpSession session = request.getSession();// 得到session
//ServletContext application = super.getServletContext();
//Integer accessCount = (Integer) application.getAttribute("accessCount");//数据库查询出来
Integer wiewsCount=null;
Connection connection = null;
String sql="select * from t_news where id=1 ";//wiewsCount
PreparedStatement ps=null;
ResultSet rs=null;
try {
connection=getConnection();
ps = connection.prepareStatement(sql);
rs = ps.executeQuery();
if(rs.next()){
wiewsCount = rs.getInt("wiewsCount");
if(wiewsCount==null){
wiewsCount = 1;
}else{
wiewsCount = wiewsCount + 1;
Connection cn =getConnection();
String sql1="update t_news set wiewsCount="+wiewsCount+" where id=1";
PreparedStatement prepareStatement = cn.prepareStatement(sql1);
int executeUpdate = prepareStatement.executeUpdate();
if(executeUpdate>0){
System.out.println("1");
}else{
System.out.println(2);
}
cn.close();
cn=null;
prepareStatement.close();
prepareStatement=null;
}
}
} catch (SQLException e) {
e.printStackTrace();
}finally{
try {
connection.close();
connection=null;
ps.close();
ps=null;
rs.close();
rs=null;
} catch (SQLException e) {
e.printStackTrace();
}
}
Integer ac;
try {
ac = accessCount(request, response);
out.println("模拟值="+ac+"\t数据库值="+wiewsCount);
} catch (Exception e) {
e.printStackTrace();
}
out.flush();
out.close();
}
public static Integer accessCount(HttpServletRequest request,HttpServletResponse response)throws Exception{
HttpServletRequest hs=(HttpServletRequest)request;
ServletContext application = hs.getServletContext();
Integer accessCount = (Integer) application.getAttribute("accessCount");//数据库查询出来
//if=null
if (accessCount == null) {
accessCount = 1;
application.setAttribute("accessCount", accessCount);
} else {
//else +1并修改数据库的值
accessCount = accessCount + 1;
application.setAttribute("accessCount", accessCount);
//update
}
return accessCount;
}
/**
* @return
*/
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName(Driver);
conn = DriverManager.getConnection(Url, UserName, PassWord);
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
private static String Driver = "com.mysql.jdbc.Driver";// ConfigUtils.getProperty("jdbc.driver");
private static String Url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8";// ConfigUtils.getProperty("jdbc.url");
private static String UserName = "root";// ConfigUtils.getProperty("jdbc.userName");
private static String PassWord = "root";// ConfigUtils.getProperty("jdbc.passWord");
}
相关文章推荐
- 64位Centos7上汇编运行32位程序
- 伪类选择器和伪元素
- Git远程操作详解
- APP切图那点事儿–详细介绍android和ios平台
- svn 将本地文件add到仓库中
- XML 文档定义有几种形式?它们之间有何本质区别?解析 XML 文档有哪几 种方式?
- 微软100题(73)对称字符串的最大长度
- 二进制搜索
- String.format() 格式化字符串
- ie 跨域,别的网站用iframe嵌进去后无法读取session
- Android Path和PathMeasure类的使用之获取圆弧上的坐标值
- 设计模式之 - 状态模式
- 转:MVC3开发常常遇到的问题及常常使用到的代码片段
- Windows客户端开发简介(四)
- 一切成功源于积累——20150610 外汇经典时刻之官员讲话 日本央行 2000点 虐杀
- cocos2dx Socket(三)
- 杭电ACM1407——测试你是否和LTC水平一样高
- 微软100题(72)单例模式
- Spring4.14 事务异常 NoUniqueBeanDefinitionException: No qualifying bean of type [....PlatformTransactionManager]
- 【json的使用】