基于Struts2 的日志管理系统的Java实现
1、首先,项目的架构如下:
2、com.sxl.dba 中:OracleConnector.java
package com.sxl.dba;
import java.sql.*;
//设计模式1:单例模式
public class OracleConnector {
private static Connection conn;
public static Connection getOracleConn()
{
//java bean
try
{
//判断是否有打开过连接,如果打开过则返回已有连接,
//如果没有打开过则新建立连接
if(conn==null)
{
Class.forName("oracle.jdbc.OracleDriver");
String url="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
String user="system";
String pass="orcl1234"; //通过驱动管理器获取 oracle数据库连接
conn= DriverManager.getConnection(url, user, pass);
System.out.println("数据库连接成功!");
}
}
catch(Exception ex)
{
System.out.println("数据库连接失败:"+ex.getMessage());
} return conn;
}
}
3、com.sxl.pojos 中:Log.java 和User.java
package com.sxl.pojos; import java.util.Date; public class Log { //对应数据库表名:log
private int lid; //日志ID
private String title; //日志标题
private String content; //日志内容
private int uid; //用户ID,对应的数据库字段:userid
private Date date; //日志日期,对应数据库字段:logdate public int getLid() {
return lid;
}
public void setLid(int lid) {
this.lid = lid;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
public int getUid() {
return uid;
}
public void setUid(int uid) {
this.uid = uid;
}
public Date getDate() {
return date;
}
public void setDate(Date date) {
this.date = date;
}
//构造函数
public Log(int lid, String title, String content, int uid, Date date) {
super();
this.lid = lid;
this.title = title;
this.content = content;
this.uid = uid;
this.date = date;
}
public Log() {
super();
// TODO Auto-generated constructor stub
}
@Override
public String toString() {
return "Log [lid=" + lid + ", title=" + title + ", content=" + content
+ ", uid=" + uid + ", date=" + date + "]";
} }
package com.sxl.pojos; public class User { //对应数据库表名为:loguser
private int uid; //用户ID,对应的数据库字段:userid
private String name; //用户姓名
private String pass; //用户密码 public int getUid() {
return uid;
}
public void setUid(int uid) {
this.uid = uid;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
} public User(int uid, String name, String pass) {
super();
this.uid = uid;
this.name = name;
this.pass = pass;
}
public User() {
super();
// TODO Auto-generated constructor stub
}
@Override
public String toString() {
return "User [uid=" + uid + ", name=" + name + ", pass=" + pass + "]";
}
}
4、com.sxl.services 中:LogService.java 和UserService.java
package com.sxl.services; import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import com.sxl.pojos.Log; public class LogService {
private Connection conn=null; public LogService() {
conn=com.sxl.dba.OracleConnector.getOracleConn();
} //根据日志ID查找
public Log findByLid(int lid) {
if (conn!=null) {
try {
Statement st=conn.createStatement();
String sql="select * from log where lid='"+lid+"'";
ResultSet rs=st.executeQuery(sql); if (rs.next()) {
Log log=new Log();
log.setContent(rs.getString("content"));
log.setTitle(rs.getString("title"));
log.setLid(rs.getInt("lid"));
log.setUid(rs.getInt("uid"));
return log;
}else {
System.out.println("连接出错,未查到!");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} }
return null;
} //添加日志
public boolean add(Log log) {
try {
Statement st=conn.createStatement(); DateFormat format1=new SimpleDateFormat("yyyy-MM-dd");
String date=format1.format(log.getDate()); String sql="insert into log(title,content,userid,logdate) values('"+log.getTitle()+"','"+log.getContent()+"','"+log.getUid()+"','"+date+"')";
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
} //修改日志
public boolean modify(Log log) {
try {
Statement st=conn.createStatement();
Date nowDate=new Date();
DateFormat format1=new SimpleDateFormat("yyyy-MM-dd");
String date=format1.format(nowDate);
String sql="update log set title='"+log.getTitle()+"',content='"+log.getContent()+"',logdate='"+date+"',where lid="+log.getLid();
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
} //根据用户ID查找
public List<Log> findByUid(int uid) {
List<Log> list=new ArrayList<Log>();
if (conn!=null) {
try {
Statement st=conn.createStatement();
System.out.println("进入查询...");
String sql="select * from log where userid='"+uid+"'";
ResultSet rs=st.executeQuery(sql);
while (rs.next()) {
System.out.println("查询结果为:");
Log log=new Log(); log.setContent(rs.getString("content"));
log.setTitle(rs.getString("title"));
log.setLid(rs.getInt("lid"));
log.setUid(rs.getInt("uid"));
log.setDate(rs.getDate("date")); list.add(log);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return list;
} //删除日志
public boolean del(int lid) {
try {
Statement st=conn.createStatement();
String sql="delete from log where lid="+lid;
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
}
}
package com.sxl.services; import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement; import com.sxl.pojos.User; public class UserService {
private Connection conn=null; public UserService() {
conn=com.sxl.dba.OracleConnector.getOracleConn();
} //检查(查找)用户
public int find(User user) {
if (conn!=null) {
try {
Statement st=conn.createStatement();
String sql="select userid from loguser where name='"+user.getName().replace('\'', ' ')+"' and pass='"+user.getPass().replace('\'', ' ')+"'";
ResultSet rs=st.executeQuery(sql); if (rs.next()) {
return rs.getInt("uid");
}else {
System.out.println("对不起,该用户不存在");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return -1;
} //添加用户
public boolean add(User user) {
try {
Statement st=conn.createStatement();
String sql="insert into loguser values('"+user.getUid()+"','"+user.getName()+"','"+user.getPass()+"')";
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
} //修改用户
public boolean modify(User user) {
try {
Statement st=conn.createStatement();
String sql="update loguser set name='"+user.getName()+"',pass='"+user.getPass()+"' where userid="+user.getUid();
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
} //删除用户
public boolean del(int uid) {
try {
Statement st=conn.createStatement();
String sql="delete from loguser where userid="+uid;
st.execute(sql);
return true;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return false;
}
}
5、com.sxl.actions 中:LogAction.java 和UserAction.java
package com.sxl.actions; import java.text.DateFormat;
import java.util.Date; import javax.servlet.http.HttpServletRequest; import org.apache.struts2.ServletActionContext; import java.util.List;
import com.opensymphony.xwork2.ActionSupport; import com.sxl.pojos.Log;
import com.sxl.services.LogService; public class LogAction extends ActionSupport {
private int uid;
private int lid;
private Log log; //提取出公共的部分
private LogService logService=new LogService();
HttpServletRequest request=ServletActionContext.getRequest(); public int getUid() {
return uid;
} public void setUid(int uid) {
this.uid = uid;
} public int getLid() {
return lid;
} public void setLid(int lid) {
this.lid = lid;
} public Log getLog() {
return log;
} public void setLog(Log log) {
this.log = log;
} public String add() throws Exception {
log.setDate(new Date());
if (logService.add(log)) {
return "success";
}else {
return "failed";
}
} public String getAllLog() throws Exception{
List<Log> logList=logService.findByUid(uid);
request.setAttribute("logList", logList);
return "getAllLog";
} public String getByLid() throws Exception{
Log log=logService.findByLid(lid);
request.setAttribute("log", log);
return "logModify";
} public String del() throws Exception{
if (logService.del(lid)) {
List<Log> logList=logService.findByUid(uid);
request.setAttribute("logList", logList);
return "success";
}
return "failed";
} public String modify () throws Exception {
System.out.println("修改:"+log.toString());
if (logService.modify(log)) {
return "success";
}
return "failed";
}
}
package com.sxl.actions; import javax.servlet.http.HttpServletRequest; import org.apache.struts2.ServletActionContext; import com.opensymphony.xwork2.ActionSupport;
import com.sxl.pojos.User;
import com.sxl.services.LogService;
import com.sxl.services.UserService; public class UserAction extends ActionSupport {
private User user;
private String validatePass; //提取出公共的部分
private UserService userService=new UserService();
HttpServletRequest request=ServletActionContext.getRequest(); public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public String getValidatePass() {
return validatePass;
}
public void setValidatePass(String validatePass) {
this.validatePass = validatePass;
} //用户登录
public String login() throws Exception {
int uid=userService.find(user);
if (uid!=-1) {
user.setUid(uid);
request.getSession().setAttribute("user", user);
return "personalCenter";
}else {
return "failed";
}
} //添加用户
public String add() throws Exception {
if (!user.getPass().equals(validatePass)) {
return "failed";
}
if (userService.add(user)) {
return "personalCenter";
}else {
return "failed";
}
} public String modify() throws Exception{
if (!user.getPass().equals(validatePass)) {
return "failed";
}if (userService.modify(user)) {
return "success";
}else {
return "failed";
}
}
}
6、struts.xml 配置文件如下:
对应的代码:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts> <package name="logsystem" namespace="/" extends="struts-default">
<action name="user" class="com.sxl.actions.UserAction">
<result name="personalCenter" type="dispatcher">/personalCenter.jsp</result>
<result name="success" type="dispatcher">/success.jsp</result>
<result name="failed" type="redirect">/failed.jsp</result>
</action> <action name="log" class="com.sxl.actions.LogAction">
<result name="getAllLog" type="dispatcher">/getAllLog.jsp</result>
<result name="success" type="dispatcher">/success.jsp</result>
<result name="logModify" type="dispatcher">/logModify.jsp</result>
<result name="failed" type="redirect">/failed.jsp</result>
</action>
</package>
</struts>
& jsp s~
基于Struts2 的日志管理系统的Java实现的更多相关文章
- 基于struts2的学生报道管理系统(附github源码地址)
本项目参考了<java web轻量级开发全体验>,加入了对mysql的支持. 一.基本业务功能 通过struts2框架,结合mysql数据库构建一个学生报到管理系统,来模拟学生报到登记的过 ...
- 基于SSH实现员工管理系统之框架整合篇
本篇文章来源于:https://blog.csdn.net/zhang_ling_yun/article/details/77803178 以下内容来自慕课网的课程:基于SSH实现员工管理系统之框架整 ...
- 离线部署ELK+kafka日志管理系统【转】
转自 离线部署ELK+kafka日志管理系统 - xiaoxiaozhou - 51CTO技术博客http://xiaoxiaozhou.blog.51cto.com/4681537/1854684 ...
- 日志管理系统ELK6.2.3
https://www.jianshu.com/p/88f2cbedcc2a 写在前面 刚毕业工作的时候,处理日志喜欢自己写脚本抓取数据分析日志,然后在zabbix上展示出来.但是开发要看日志的时候, ...
- 基于Struts2框架实现登录案例 之 使用Struts2标签库简化表单+继承ActionSupport完成输入交验
一,使用Struts2标签库简化表单 在文章[基于Struts2框架实现登录案例]的基础上,通过使用Struts标签库可以简化登录页面login2.jsp <%@ page language=& ...
- 【课程分享】基于plusgantt的项目管理系统实战开发(Spring3+JDBC+RMI的架构、自己定义工作流)
基于plusgantt的项目管理系统实战开发(Spring3+JDBC+RMI的架构.自己定义工作流) 课程讲师:张弘 课程分类:Java 适合人群:中级 课时数量:37课时 用到技术:Spring ...
- Eventlog Analyzer日志管理系统、日志分析工具、日志服务器的功能及作用
Eventlog Analyzer日志管理系统.日志分析工具.日志服务器的功能及作用 Eventlog Analyzer是用来分析和审计系统及事件日志的管理软件,能够对全网范围内的主机.服务器.网络设 ...
- 基于hive的日志分析系统
转自 http://www.cppblog.com/koson/archive/2010/07/19/120773.html hive 简介 hive 是一个基于 ...
- 基于UML的毕业设计管理系统的分析与设计
基于UML的毕业设计管理系统的分析与设计 <本段与标题无关,自行略过 最近各种忙,天气不错,导师心情不错:“我们要写一个关于UML的专著”,一句话:“一个完整的系统贯穿整个UML的知识”:我:“ ...
随机推荐
- MySQL存储过程的基本函数(三)
(1).字符串类 首先定义一个字符串变量:set @str="lxl"; CHARSET(str) //返回字串字符集 select charset(@str);+-------- ...
- java编程思想-注解思维导图
- 使用OpenFileDialog实现图片上传
demo效果图:
- Android开发手记(19) 数据存储四 ContentProvider
转载自:http://www.cnblogs.com/devinzhang/archive/2012/01/20/2327863.html Android为数据存储提供了五种方式: 1.SharedP ...
- Oracle_Flashback_技术_总结
Oracle Flashback 技术 总结 Flashback 技术是以Undo segment中的内容为基础的, 因此受限于UNDO_RETENTON参数.要使用flashback 的特性,必须启 ...
- EBS基础—表的后缀
1._ALL或无后缀:基表,所有对数据操作最终都是对基表的操作,表包含所有不同经营单位的信息,多组织环境. 2._B/_T:也是一种基表.一些数据和验证存储在此表中. 3._TL:语言的基表,TL表支 ...
- Android热更新开源项目Tinker集成实践总结
前言 最近项目集成了Tinker,开始认为集成会比较简单,但是在实际操作的过程中还是遇到了一些问题,本文就会介绍在集成过程大家基本会遇到的主要问题. 考虑一:后台的选取 目前后台功能可以通过三种方式实 ...
- Puer是一个可以实时编辑刷新的前端服务器
##Puer是一个可以实时编辑刷新的前端服务器 确保你安装了nodejs(现在还有没nodejs环境的前端? 拖出去喂狗吧) 使用npm全局安装puer命令 npm install puer -g 输 ...
- java_reflect_02
按我们所知道的.对于类中的method,constructor,field如果访问属性是private的情况下我们是访问不了的,但通过反射就可以做到 仔细分析api发现Method,Construct ...
- Qt中QWidget加入到父类QWidget不能显示的问题
最近忙活了半天发现了一个不容易发现的问题,比如我有一个父类的自定义Widget,并且自己设置了Pattle,但这个时候我如果再在当前Widget内部加入自己的widget就不能正常显示,但是加QPus ...