先了解一些oracle数据库的基本知识,黑马之前的视频有教学如何在虚拟机搭建oracle数据库,然后在本机使用PL/SQL操作数据库。
oracle学习
在数据库中新建一个用户user,可以直接在USER中右键new一个,设置用户名ssm和密码itcast,需要给用户授权,选择角色Role privileges中的connect和resource。
然后我们就可以用刚才创建的用户来登录PL了。
我们可以新建一个SQL页面来编写sql语句,进行建表,添加数据等操作…
先搭建好maven的父工程,引入需要jar包的坐标,它用来承载项目的各个子模块,模块的创建和工程差不多,除了web层的模块我们需要使用maven的webapp骨架。
对于项目tomcat部署,可以和老师一样在web层的pom.xml中添加tomcat7插件,然后配置运行,不过我比较习惯直接部署本地的tomcat,比较方便。
<plugins>
<plugin>
<groupId>org.apache.tomcat.mavengroupId>
<artifactId>tomcat7-maven-pluginartifactId>
<configuration><port>8888port>configuration>
<version>2.2version>
plugin>
plugins>
public interface IProductDao {
//查询所有产品信息
@Select("select * from product")
public List<Product> findAll() throws Exception;
}
controller调用service,service调用dao,dao层使用注解配置sql语句查询数据库。
@Controller
@RequestMapping("/product")
public class ProductController {
@Autowired
private IProductService productService;
@RequestMapping("/findAll.do") //配置前端控制器的时候拦截的是*.do文件
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
List<Product> ps = productService.findAll();
mv.addObject("productList",ps);
mv.setViewName("product-list");
return mv;
}
}
modelAndView
public String getDepartureTimeStr() {
if(departureTime!=null){
departureTimeStr = DateUtils.data2String(departureTime,"yyyy-MM-dd HH:mm:ss");
}
return departureTimeStr;
}
public String getProductStatusStr() {
if(productStatus != null){
//状态 0 关闭 1 开启
if(productStatus==0){
productStatusStr="关闭";
}
if(productStatus==1){
productStatusStr="开启";
}
}
return productStatusStr;
}
//dao接口:
//添加
@Insert("insert into product(productNum,productName,cityName,departureTime,productPrice,productDesc,productStatus) " +
"values(#{productNum},#{productName},#{cityName},#{departureTime},#{productPrice},#{productDesc},#{productStatus})")
void save(Product product);
//controller:
//产品添加
@RequestMapping("/save.do")
public String save(Product product) throws Exception {
productService.save(product);
return "redirect:findAll.do"; //添加后重新加载列表显示
}
//实体类属性加注解
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm") //局部的处理方式
private Date departureTime; // 出发时间
//查询数据库
//订单的dao编写,涉及多表
@Select("select * from orders")
@Results({
@Result(id = true,property = "id",column = "id"),
@Result(property = "orderNum",column = "orderNum"),
@Result(property = "orderTime",column = "orderTime"),
@Result(property = "orderStatus",column = "orderStatus"),
@Result(property = "peopleCount",column = "peopleCount"),
@Result(property = "payType",column = "payType"),
@Result(property = "orderDesc",column = "orderDesc"),
@Result(property = "product",column = "productId",javaType = Product.class,
one = @One(select = "com.itheima.ssm.dao.IProductDao.findById")),
})
public List<Orders> findAll() throws Exception;
//订单的控制器
@Controller
@RequestMapping("/orders")
public class OrdersController {
@Autowired
private IOrdersService ordersService;
@RequestMapping("/findAll.do")
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
List<Orders> ordersList = ordersService.findAll();
mv.addObject("ordersList",ordersList);//orders-list.jsp中定义的变量
mv.setViewName("orders-list");
return mv;
}
}
PageHelper 是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,例如mysql、oracle、mariaDB、DB2、SQLite、Hsqldb等。
使用步骤
//查询订单涉及其他表的操作,同样需要多表查询,其中关系有一对一,一对多
//多表操作
@Select("select * from orders where id=#{ordersId}")
@Results({
@Result(id = true, property = "id", column = "id"),
@Result(property = "orderNum", column = "orderNum"),
@Result(property = "orderTime", column = "orderTime"),
@Result(property = "orderStatus", column = "orderStatus"),
@Result(property = "peopleCount", column = "peopleCount"),
@Result(property = "peopleCount", column = "peopleCount"),
@Result(property = "payType", column = "payType"),
@Result(property = "orderDesc", column = "orderDesc"),
@Result(property = "product", column = "productId", javaType = Product.class, one = @One(select = "com.itheima.ssm.dao.IProductDao.findById")),
@Result(property = "member",column = "memberId",javaType = Member.class,one = @One(select = "com.itheima.ssm.dao.IMemberDao.findById")),
@Result(property = "travellers",column = "id",javaType =java.util.List.class,many = @Many(select = "com.itheima.ssm.dao.ITravellerDao.findByOrdersId"))
})
public Orders findById(String ordersId) throws Exception;
//旅客和订单是多对多,使用中间表order_traveller 连接
//旅客
public interface ITravellerDao {
//根据订单id查询游客id,再根据游客id查询游客所有信息
@Select("select * from traveller where id in (select travellerId from order_traveller where orderId=#{ordersId})")
public List<Traveller> findByOrdersId(String ordersId) throws Exception;
}
//controller将查询到的信息携带返回给详情页
@RequestMapping("findById.do")
public ModelAndView findById(@RequestParam(name = "id",required = true)String ordersId) throws Exception {
ModelAndView mv = new ModelAndView();
Orders orders = ordersService.findById(ordersId);
mv.addObject("orders",orders);
mv.setViewName("orders-show");
return mv;
}
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
version="2.5">
<display-name>SpringSecurity314display-name>
<context-param>
<param-name>contextConfigLocationparam-name>
<param-value>classpath:spring-security.xmlparam-value>
context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
listener>
<filter>
<filter-name>springSecurityFilterChainfilter-name>
<filter-class>org.springframework.web.filter.DelegatingFilterProxyfilter-class>
filter>
<filter-mapping>
<filter-name>springSecurityFilterChainfilter-name>
<url-pattern>/*url-pattern>
filter-mapping>
<welcome-file-list>
<welcome-file>index.htmlwelcome-file>
<welcome-file>index.htmwelcome-file>
<welcome-file>index.jspwelcome-file>
<welcome-file>default.htmlwelcome-file>
<welcome-file>default.htmwelcome-file>
<welcome-file>default.jspwelcome-file>
welcome-file-list>
web-app>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:security="http://www.springframework.org/schema/security"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/security
http://www.springframework.org/schema/security/spring-security.xsd">
<security:http auto-config="true" use-expressions="false">
<security:intercept-url pattern="/**" access="ROLE_USER" />
security:http>
<security:authentication-manager>
<security:authentication-provider>
<security:user-service>
<security:user name="user" password="{noop}user"
authorities="ROLE_USER" />
<security:user name="admin" password="{noop}admin"
authorities="ROLE_ADMIN" />
security:user-service>
security:authentication-provider>
security:authentication-manager>
beans>
<security:http security="none" pattern="/login.html" />
<security:http security="none" pattern="/failer.html" />
<security:http auto-config="true" use-expressions="false" >
<security:intercept-url pattern="/**" access="ROLE_USER" />
<security:form-login login-page="/login.html"
login-processing-url="/login" username-parameter="username"
password-parameter="password" authentication-failure-url="/failer.html"
default-target-url="/success.html" authentication-success-forward-url="/success.html"
/>
<security:csrf disabled="true" />
security:http>
spring security使用数据库认证
在Spring Security中如果想要使用数据进行认证操作,有很多种操作方式,这里介绍使用UserDetails、UserDetailsService来完成操作。
public interface IUserService extends UserDetailsService {
}
// UserServiceImpl
@Service("userService")
@Transactional
public class UserServiceImpl implements IUserService {
@Autowired
private IUserDao userDao;
//完成验证
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
UserInfo userInfo = null;
try {
userInfo = userDao.findByUsername(username);
} catch (Exception e) {
e.printStackTrace();
}
//处理自己的用户对象,封装成UserDetails
// User user = new User(userInfo.getUsername(),"{noop}"+userInfo.getPassword(),getAuthority(userInfo.getRoles()));
User user = new User(userInfo.getUsername(),"{noop}"+userInfo.getPassword(),userInfo.getStatus() == 0 ? false:true,true,true,true,getAuthority(userInfo.getRoles()));
return user;
}
//这里面的role信息是查询用户的时候携带过来的
//作用就是返回一个list集合,集合中装入的是角色描述
public List<SimpleGrantedAuthority> getAuthority(List<Role> roles){
List<SimpleGrantedAuthority> list = new ArrayList<>();
for(Role role : roles){
list.add(new SimpleGrantedAuthority("ROLE"+role.getRoleName())); //添加角色
}
return list;
}
}
public interface IUserDao {
@Select("select * from users where username=#{username}")
@Results({
@Result(id = true,property = "id",column = "id"),
@Result(property = "username",column = "username"),
@Result(property = "email",column = "email"),
@Result(property = "password",column = "password"),
@Result(property = "phoneNum",column = "phoneNum"),
@Result(property = "status",column = "status"),
@Result(property = "roles",column = "id",javaType = java.util.List.class,many = @Many(select = "com.itheima.ssm.dao.IRoleDao.findRoleByUserId")),
})
public UserInfo findByUsername(String username) throws Exception;
}
//查询用户对应角色信息涉及多表查询,多对多使用中间表
public interface IRoleDao {
//根据用户id查找所有对应角色信息
@Select("select * from role where id in (select roleId from users_role where userId=#{userId})")
public List<Role> findRoleByUserId(String userId) throws Exception;
}
与之前查询产品类似操作,在页面上无法显示的数据大部分是因为数据库中存储的格式,在页面上显示的是string形式,因此在domain中需要去转换。
@Controller
@RequestMapping("/user")
public class UserController {
@Autowired
private IUserService userService;
@RequestMapping("/findAll.do")
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
List<UserInfo> userList = userService.findAll();
mv.addObject("userList",userList);
mv.setViewName("user-list");
return mv;
}
}
点击跳转到添加用户的界面,提交后表单将数据发送给controller,再一层层调用到dao添加用户,需要注意的是,添加数据时用户的密码需要加密。
之前我们在用户认证的时候,使用的密码是明文去访问,是不安全的,因此需要在密码前加:{noop},如果是密文则不需要添加。
配置加密:
在spring-security中有关于密码加密的配置:
可以直接将其封装成bean,也可以自己写一个工具类使用:
//密码加密的工具类
public class BCryptPasswordEncoderUtils {
public static BCryptPasswordEncoder bCryptPasswordEncoder = new BCryptPasswordEncoder();
public static String encodePassword(String password){
return bCryptPasswordEncoder.encode(password);
}
//测试
public static void main(String[] args){
String password = "123";
String pwd = encodePassword(password);
System.out.println(pwd); //每一次加密的结果都不一样
}
}
@Autowired
private BCryptPasswordEncoder bCryptPasswordEncoder; //密码加密
//添加用户
@Override
public void save(UserInfo userInfo) throws Exception {
//对密码进行加密处理
userInfo.setPassword(bCryptPasswordEncoder.encode(userInfo.getPassword())); //加密后在重新赋予
userDao.save(userInfo); //添加的密码是加密后的
}
//用户添加
@Insert("insert into users(email,username,password,phoneNum,status) values(#{email},#{username},#{password},#{phoneNum},#{status})")
void save(UserInfo userInfo) throws Exception;
//controller
//用户添加
@RequestMapping("/save.do")
public String save(UserInfo userInfo) throws Exception {
userService.save(userInfo);
return "redirect:findAll.do"; //添加完应该再查询一次
}
到此,我们可以使用自己添加的用户进行登录了。
通过id查询用户 – > 查询对应角色 --> 查询角色对应权限,全部信息都封装在userInfo中,然后经过controller处理后到jsp页面显示。
//查询指定id的用户
@RequestMapping("/findById.do")
public ModelAndView findById(String id) throws Exception {
ModelAndView mv = new ModelAndView();
UserInfo userInfo = userService.findById(id);
mv.addObject("user",userInfo);
mv.setViewName("user-show");
return mv;
}
dao层代码:
//IUserDao
//根据id查询用户信息
@Select("select * from users where id=#{id}")
@Results({
@Result(id = true,property = "id",column = "id"),
@Result(property = "username",column = "username"),
@Result(property = "email",column = "email"),
@Result(property = "password",column = "password"),
@Result(property = "phoneNum",column = "phoneNum"),
@Result(property = "status",column = "status"),
@Result(property = "roles",column = "id",javaType = java.util.List.class,many = @Many(select = "com.itheima.ssm.dao.IRoleDao.findRoleByUserId")),
})
UserInfo findById(String id) throws Exception;
//IRoleDao
//根据用户id查找所有对应角色信息
@Select("select * from role where id in (select roleId from users_role where userId=#{userId})")
@Results({
@Result(id = true,property = "id",column = "id"),
@Result(property = "roleName",column = "roleName"),
@Result(property = "roleDesc",column = "roleDesc"),
//会根据role的id来查询当前权限信息
@Result(property = "permissions",column = "id",javaType = java.util.List.class,many = @Many(select = "com.itheima.ssm.dao.IPermissionDao.findPermissionByRoleId")),
})
public List<Role> findRoleByUserId(String userId) throws Exception;
@Select("select * from permission where id in (select permissionId from role_permission where roleId=#{id})")
public List<Permission> findPermissionByRoleId(String id) throws Exception;
展示信息:
使用AdminLTE框架的树表格,模仿搭建出显示用户详情的页面,因为用户可能有多个角色,所以使用foreach从数据库获取数据构建li,并且一个角色可能对于多个权限,所以需要多嵌套一层foreach,并且权限和用户的对应显示列表需要修改一下。
后续还会做一些管理,用户管理角色,角色管理权限,现在是为后面的工作铺垫。
//Controller
@RequestMapping("/findAll.do")
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
List<Role> roleList = roleService.findAll();
mv.addObject("roleList",roleList);
mv.setViewName("role-list");
return mv;
}
//IRoleDao
//查询所有角色
@Select("select * from role")
List<Role> findAll() throws Exception;
//Controller
//添加角色
@RequestMapping("/save.do")
public String save(Role role) throws Exception {
roleService.save(role);
return "redirect:findAll.do"; //添加完查询一下
}
//dao
//添加角色
@Insert("insert into role(roleName,roleDesc) values(#{roleName},#{roleDesc})")
void save(Role role) throws Exception;
//Controlle
//查询用户以及用户可以添加的角色
@RequestMapping("/findUserByIdAndAllRole")
public ModelAndView findUserByIdAndAllRole(@RequestParam(name = "id",required = true) String userId) throws Exception {
ModelAndView mv = new ModelAndView();
//1 根据用户id查询用户
UserInfo userInfo = userService.findById(userId);
//2 根据用户id查询可以添加的角色
List<Role> otherRoles = userService.findOtherRoles(userId); //角色是可以多选的
mv.addObject("user",userInfo);
mv.addObject("roleList",otherRoles);
mv.setViewName("user-role-add");
return mv;
}
//dao
//查询用户没有的角色(可添加的)
@Select("select * from role where id not in (select roleId from users_role where userId=#{userId})")
List<Role> findOtherRoles(String userId) throws Exception;
//Controller
//给用户添加角色 -- 往中间表插数据
@RequestMapping("/addRoleToUser.do")
public String addRoleToUser(@RequestParam(name = "userId",required = true) String userId,
@RequestParam(name = "ids",required = true) String[] roleIds) throws Exception {
userService.addRoleToUser(userId,roleIds);
return "redirect:findAll.do";
}
关于param注解解决多参数问题:@Param
//Service
//给用户添加角色
@Override
public void addRoleToUser(String userId, String[] roleIds) throws Exception {
for (String roleId : roleIds) {
userDao.addRoleToUser(userId,roleId);
}
}
//dao
//给用户添加角色
/*
@Param是MyBatis所提供的,作为Dao层的注解,作用是用于传递参数,从而可以与SQL中的的字段名相对应。
报错:mybatis.system... 是因为它将我们传递的两个参数#{userId},#{roleId},都认为是String userId这个对象的属性
*/
@Insert("insert into users_role (userId,roleId) values(#{userId},#{roleId})")
void addRoleToUser(@Param("userId") String userId, @Param("roleId") String roleId) throws Exception;
和上面用户与角色管理类似,先查询角色可以添加的权限,再把选择的权限添加给角色。
//Controller
//根据roleId查询角色,并查询可以添加的权限信息
@RequestMapping("/findRoleByIdAndAllPermission")
public ModelAndView findRoleByIdAndAllPermission(@RequestParam(name = "id",required = true) String roleId) throws Exception {
ModelAndView mv = new ModelAndView();
//根据roleId查询role
Role role = roleService.findById(roleId);
//根据roleId查询可以添加的权限
List<Permission> otherPermissions = roleService.findOtherPermissions(roleId);
mv.addObject("role",role);
mv.addObject("permissionList",otherPermissions);
mv.setViewName("role-permission-add");
return mv;
}
//给角色添加权限
@RequestMapping("/addPermissionToRole")
public String addPermissionToRole(@RequestParam(name = "roleId",required = true) String roleId,
@RequestParam(name = "ids",required = true) String[] permissionIds) throws Exception {
roleService.addPermissionToRole(roleId,permissionIds);
return "redirect:findAll.do";
}
//dao
//根据roleId查询角色可以添加的权限信息
@Select("select * from permission where id not in (select permissionId from role_permission where roleId=#{roleId})")
List<Permission> findOtherPermissions(String roleId) throws Exception;
//给角色添加权限 --- 操作中间表role_permission
@Insert("insert into role_permission(roleId,permissionId) values(#{roleId},#{permissionId})")
void addPermissionToRole(@Param("roleId") String roleId,@Param("permissionId") String permissionId);
在服务器端我们可以通过Spring security提供的注解对方法来进行权限控制。Spring Security在方法的权限控制上支持三种类型的注解,JSR-250注解、@Secured注解和支持表达式的注解,这三种注解默认都是没有启用的,需要单独通过global-method-security元素的对应属性进行启用。
<security:global-method-security jsr250-annotations="enabled">security:global-method-security>
@RequestMapping("/findAll.do")
@RolesAllowed("ADMIN") //只有ADMIN可以访问,也可以是一个数组,省略前缀ROLE_
public ModelAndView findAll() throws Exception {
...
}
<dependency>
<groupId>javax.annotationgroupId>
<artifactId>jsr250-apiartifactId>
<version>1.0version>
dependency>
<error-page>
<error-code>403error-code>
<location>/403.jsplocation>
error-page>
需要在web.xml中配置,不需要额外导入依赖,是springframework包中带的。
<security:global-method-security secured-annotations="enabled">security:global-method-security>
@RequestMapping("/findAll.do")
@Secured("ROLE_ADMIN") //不可省略前缀
public ModelAndView findAll( ...
<security:global-method-security pre-post-annotations="enabled">security:global-method-security>
//controller
//查询所有
@RequestMapping("/findAll.do")
@PreAuthorize("hasRole('ROLE_ADMIN')") //限制角色
public ModelAndView findAll() throws Exception {
...
}
//用户添加
@RequestMapping("/save.do")
@PreAuthorize("authentication.principal.username == 'tom'") //限制用户
public String save(UserInfo userInfo) throws Exception {
...
}
步骤:
<dependency>
<groupId>org.springframework.securitygroupId>
<artifactId>spring-security-taglibsartifactId>
<version>${spring.security.version}version>
dependency>
<%@taglib uri="http://www.springframework.org/security/tags" prefix="security"%>
<bean id="webexpressionHandler" class="org.springframework.security.web.access.expression.DefaultWebSecurityExpressionHandler">bean>
需要在数据库中创建存储日志信息的表,并添加对应的实体类,另外需要编写一个切面类处理日志信息,将日志信息封装到实体类中,封装后的日志信息就可以调用service – 》 dao 存储到数据库中。
//LogAop。java
@Component
@Aspect
public class LogAop {
@Autowired
private HttpServletRequest request; //得到request,web.xml中配置监听器
@Autowired
private ISysLogService sysLogService;
private Date visitTime; //开始时间
private Class clazz; //访问的类
private Method method; //访问的方法
//前置通知 主要是获取开始时间,执行的类是哪一个,访问的是哪一个方法
@Before("execution(* com.itheima.ssm.controller.*.*(..))")
public void doBefore(JoinPoint jp) throws NoSuchMethodException {
visitTime = new Date(); //当前时间就是开始访问的时间
clazz = jp.getTarget().getClass(); //具体要访问的类
String methodName = jp.getSignature().getName(); //获取访问的方法的名称
Object[] args = jp.getArgs();//获取访问方法的参数
//获取具体执行的方法放入method对象
if(args == null || args.length == 0){
//无参
method = clazz.getMethod(methodName); //根据方法名获取方法对象,只能获取无参数的方法
}else {
Class[] classArgs = new Class[args.length];
for (int i = 0; i < args.length; i++) {
classArgs[i] = args[i].getClass(); //获取每一个参数的class存储到数组中
}
method = clazz.getMethod(methodName,classArgs);
}
}
//后置通知
@After("execution(* com.itheima.ssm.controller.*.*(..))")
public void doAfter(JoinPoint jp) throws Exception {
//获取访问时长
long time = new Date().getTime() - visitTime.getTime();
//获取url
String url = "";
if(clazz!=null && method!=null && clazz!= LogAop.class){
//1 获取类上的@RequestMapping("/orders")
RequestMapping classAnnotation = (RequestMapping) clazz.getAnnotation(RequestMapping.class);
if(classAnnotation!=null){
String[] classValue = classAnnotation.value();
//2 获取方法上的@RequestMapping(xxx)
RequestMapping methodAnnotation = method.getAnnotation(RequestMapping.class);
if(methodAnnotation!=null){
String[] methodValue = methodAnnotation.value();
url = classValue[0]+methodValue[0]; //拼接url /orders/findAll.do
}
}
}
//获取当前访问的ip地址
String ip = request.getRemoteAddr();
//获取当前操作的用户
//SecurityContext context = request.getSession().getAttribute("SPRING_SECURITY_CONTEXT") 也可以通过request对象获取
SecurityContext context = SecurityContextHolder.getContext(); //从上下文中获取当前登录的用户
User user = (User) context.getAuthentication().getPrincipal();
String username = user.getUsername();
//将日志相关信息封装到SysLog对象
Syslog syslog = new Syslog();
syslog.setExecutionTime(time);
syslog.setIp(ip);
syslog.setMethod("[类名]"+clazz.getName()+"[方法名]"+method.getName());
syslog.setUrl(url);
syslog.setUsername(username);
syslog.setVisitTime(visitTime);
//调用service完成操作
sysLogService.save(syslog);
}
}
<listener>
<listener-class>org.springframework.web.context.request.RequestContextListenerlistener-class>
listener>
@Controller
@RequestMapping("/sysLog")
public class SysLogController {
@Autowired
private ISysLogService sysLogService;
@RequestMapping("/findAll.do")
public ModelAndView findAll() throws Exception {
ModelAndView mv = new ModelAndView();
List<Syslog> syslogList = sysLogService.findAll();
mv.addObject("sysLogs",syslogList);
mv.setViewName("syslog-list");
return mv;
}
}
public interface ISysLogDao {
//添加日志
@Insert("insert into syslog(visitTime,username,ip,url,executionTime,method) values(#{visitTime},#{username},#{ip},#{url},#{executionTime},#{method})")
public void save(Syslog syslog) throws Exception;
//查询日志
@Select("select * from sysLog")
List<Syslog> findAll() throws Exception;
}
if(clazz.getName() == "com.itheima.ssm.controller.SysLogController"){
return;
}
//调用service完成操作
sysLogService.save(syslog);
总结: