`
oywl2008
  • 浏览: 1051123 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

spring mvc注解例子

 
阅读更多

 

 弃用了struts,用spring mvc框架做了几个项目,感觉都不错,而且使用了注解方式,可以省掉一大堆配置文件。本文主要介绍使用注解方式配置的spring mvc,之前写的spring3.0 mvc和rest小例子没有介绍到数据层的内容,现在这一篇补上。下面开始贴代码。

文中用的框架版本:spring 3,hibernate 3,没有的,自己上网下。

web.xml配置:

<?xml version="1.0" encoding="UTF-8"?>   
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">   
  
<display-name>s3h3</display-name>   
   
<context-param>     
     
<param-name>contextConfigLocation</param-name>     
     
<param-value>classpath:applicationContext*.xml</param-value>     
 
</context-param>     
  
<listener>     
     
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>     
 
</listener>     
  
 
<servlet>     
     
<servlet-name>spring</servlet-name>     
     
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>     
     
<load-on-startup>1</load-on-startup>     
 
</servlet>     
 
<servlet-mapping>     
     
<servlet-name>spring</servlet-name>  <!-- 这里在配成spring,下边也要写一个名为spring-servlet.xml的文件,主要用来配置它的controller -->   
     
<url-pattern>*.do</url-pattern>     
 
</servlet-mapping>     
  
<welcome-file-list>   
    
<welcome-file>index.jsp</welcome-file>   
  
</welcome-file-list>   
</web-app>  

 

spring-servlet,主要配置controller的信息

<?xml version="1.0" encoding="UTF-8"?>   
  
<beans xmlns="http://www.springframework.org/schema/beans"     
       xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"     
        xmlns:context
="http://www.springframework.org/schema/context"     
   xsi:schemaLocation
="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd   
       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd   
       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd   
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"
>   
     
  
<context:annotation-config />   
       
<!-- 把标记了@Controller注解的类转换为bean -->     
      
<context:component-scan base-package="com.mvc.controller" />     
  
<!-- 启动Spring MVC的注解功能,完成请求和注解POJO的映射 -->     
      
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />     
        
       
<!-- 对模型视图名称的解析,即在模型视图名称添加前后缀 -->     
       
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"     
          p:prefix
="/WEB-INF/view/" p:suffix=".jsp" />     
           
       
<bean id="multipartResolver"     
          class
="org.springframework.web.multipart.commons.CommonsMultipartResolver"     
          p:defaultEncoding
="utf-8" />     
 
</beans>  

 

applicationContext.xml代码

<?xml version="1.0" encoding="UTF-8"?>   
<beans xmlns="http://www.springframework.org/schema/beans"  
 xmlns:aop
="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context"  
 xmlns:p
="http://www.springframework.org/schema/p" xmlns:tx="http://www.springframework.org/schema/tx"  
 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-3.0.xsd   
   http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd   
   http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd   
   http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"
>   
  
 
<context:annotation-config />   
 
<context:component-scan base-package="com.mvc" />  <!-- 自动扫描所有注解该路径 -->   
  
 
<context:property-placeholder location="classpath:/hibernate.properties" />   
  
 
<bean id="sessionFactory"  
  class
="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">   
  
<property name="dataSource" ref="dataSource" />   
  
<property name="hibernateProperties">   
   
<props>   
    
<prop key="hibernate.dialect">${dataSource.dialect}</prop>   
    
<prop key="hibernate.hbm2ddl.auto">${dataSource.hbm2ddl.auto}</prop>   
    
<prop key="hibernate.hbm2ddl.auto">update</prop>   
   
</props>   
  
</property>   
  
<property name="packagesToScan">   
   
<list>   
    
<value>com.mvc.entity</value><!-- 扫描实体类,也就是平时所说的model -->   
   
</list>   
    
</property>   
 
</bean>   
  
 
<bean id="transactionManager"  
  class
="org.springframework.orm.hibernate3.HibernateTransactionManager">   
  
<property name="sessionFactory" ref="sessionFactory" />   
  
<property name="dataSource" ref="dataSource" />   
 
</bean>   
  
 
<bean id="dataSource"  
  class
="org.springframework.jdbc.datasource.DriverManagerDataSource">   
  
<property name="driverClassName" value="${dataSource.driverClassName}" />   
  
<property name="url" value="${dataSource.url}" />   
  
<property name="username" value="${dataSource.username}" />   
  
<property name="password" value="${dataSource.password}" />   
 
</bean>   
 
<!-- Dao的实现 -->   
 
<bean id="entityDao" class="com.mvc.dao.EntityDaoImpl">     
  
<property name="sessionFactory" ref="sessionFactory" />   
 
</bean>   
 
<tx:annotation-driven transaction-manager="transactionManager" />   
 
<tx:annotation-driven mode="aspectj"/>   
     
    
<aop:aspectj-autoproxy/>     
</beans>  

 

hibernate.properties数据库连接配置

dataSource.password=123  
dataSource.username=root   
dataSource.databaseName=test   
dataSource.driverClassName=com.mysql.jdbc.Driver   
dataSource.dialect=org.hibernate.dialect.MySQL5Dialect   
dataSource.serverName=localhost:3306  
dataSource.url=jdbc:mysql://localhost:3306/test   
dataSource.properties=user=${dataSource.username};databaseName=${dataSource.databaseName};serverName=${dataSource.serverName};password=${dataSource.password}   
dataSource.hbm2ddl.auto=update  

 

配置已经完成,下面开始例子
先在数据库建表,例子用的是mysql数据库

CREATE TABLE  `test`.`student` (   
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,   
  `name` varchar(45) NOT NULL,   
  `psw` varchar(45) NOT NULL,   
  PRIMARY KEY (`id`)   
)  

 

建好表后,生成实体类

package com.mvc.entity;   
  
import java.io.Serializable;   
  
import javax.persistence.Basic;   
import javax.persistence.Column;   
import javax.persistence.Entity;   
import javax.persistence.GeneratedValue;   
import javax.persistence.GenerationType;   
import javax.persistence.Id;   
import javax.persistence.Table;   
  
@Entity  
@Table(name = "student")   
public class Student implements Serializable {   
    private static final long serialVersionUID = 1L;   
    @Id  
    @Basic(optional = false)   
    @GeneratedValue(strategy = GenerationType.IDENTITY)   
    @Column(name = "id", nullable = false)   
    private Integer id;   
    @Column(name = "name")   
    private String user;   
    @Column(name = "psw")   
    private String psw;   
    public Integer getId() {   
        return id;   
    }   
    public void setId(Integer id) {   
        this.id = id;   
    }   
       
    public String getUser() {   
        return user;   
    }   
    public void setUser(String user) {   
        this.user = user;   
    }   
    public String getPsw() {   
        return psw;   
    }   
    public void setPsw(String psw) {   
        this.psw = psw;   
    }   
}  


Dao层实现

package com.mvc.dao;   
  
import java.util.List;   
  
public interface EntityDao {   
    
public List<Object> createQuery(final String queryString);   
    
public Object save(final Object model);   
    
public void update(final Object model);   
    
public void delete(final Object model);   
}
  

 

package com.mvc.dao;   
  
import java.util.List;   
  
import org.hibernate.Query;   
import org.springframework.orm.hibernate3.HibernateCallback;   
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;   
  
public class EntityDaoImpl extends HibernateDaoSupport implements EntityDao{   
    
public List<Object> createQuery(final String queryString) {   
        
return (List<Object>) getHibernateTemplate().execute(   
                
new HibernateCallback<Object>() {   
                    
public Object doInHibernate(org.hibernate.Session session)   
                            
throws org.hibernate.HibernateException {   
                        Query query 
= session.createQuery(queryString);   
                        List
<Object> rows = query.list();   
                        
return rows;   
                    }
   
                }
);   
    }
   
    
public Object save(final Object model) {   
        
return  getHibernateTemplate().execute(   
                
new HibernateCallback<Object>() {   
                    
public Object doInHibernate(org.hibernate.Session session)   
                            
throws org.hibernate.HibernateException {   
                        session.save(model);   
                        
return null;   
                    }
   
                }
);   
    }
   
    
public void update(final Object model) {   
        getHibernateTemplate().execute(
new HibernateCallback<Object>() {   
            
public Object doInHibernate(org.hibernate.Session session)   
                    
throws org.hibernate.HibernateException {   
                session.update(model);   
                
return null;   
            }
   
        }
);   
    }
   
    
public void delete(final Object model) {   
        getHibernateTemplate().execute(
new HibernateCallback<Object>() {   
            
public Object doInHibernate(org.hibernate.Session session)   
                    
throws org.hibernate.HibernateException {   
                session.delete(model);   
                
return null;   
            }
   
        }
);   
    }
   
}
  


Dao在applicationContext.xml注入

<bean id="entityDao" class="com.mvc.dao.EntityDaoImpl">  
  
<property name="sessionFactory" ref="sessionFactory" />
 
</bean>

 

Dao只有一个类的实现,直接供其它service层调用,如果你想更换为其它的Dao实现,也只需修改这里的配置就行了。
开始写view页面,WEB-INF/view下新建页面student.jsp,WEB-INF/view这路径是在spring-servlet.xml文件配置的,你可以配置成其它,也可以多个路径。student.jsp代码

<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding
="UTF-8"
%>  
<%@ include file="/include/head.jsp"%>  
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>添加</title>  
<script language="javascript" src="<%=request.getContextPath()%><!--   
/script/jquery.min.js"
>  
// --></script>  
<style><!--   
table
{  border-collapse:collapse;  }   
td
{  border:1px solid #f00;  }   
--></style><style mce_bogus="1">table{  border-collapse:collapse;  }   
td
{  border:1px solid #f00;  }</style>  
<script type="text/javascript"><!--   
function add(){   
    window.location.href
="<%=request.getContextPath() %>/student.do?method=add";   
}
   
  
function del(id){   
$.ajax( 
{   
    type : 
"POST",   
    url : 
"<%=request.getContextPath()%>/student.do?method=del&id=" + id,   
    dataType: 
"json",   
    success : 
function(data) {   
        
if(data.del == "true"){   
            alert(
"删除成功!");   
            $(
"#" + id).remove();   
        }
   
        
else{   
            alert(
"删除失败!");   
        }
   
    }
,   
    error :
function(){   
        alert(
"网络连接出错!");   
    }
   
}
);   
}
   
// --></script>  
</head>  
<body>  
  
<input id="add" type="button" onclick="add()" value="添加"/>  
<table >  
    
<tr>  
        
<td>序号</td>  
        
<td>姓名</td>  
        
<td>密码</td>  
        
<td>操作</td>  
    
</tr>  
    
<c:forEach items="${list}" var="student">  
    
<tr id="<c:out value="${student.id}"/>">  
        
<td><c:out value="${student.id}"/></td>  
        
<td><c:out value="${student.user}"/></td>  
        
<td><c:out value="${student.psw}"/></td>  
        
<td>  
            
<input type="button" value="编辑"/>        
            
<input type="button" onclick="del('<c:out value="${student.id}"/>')" value="删除"/>  
        
</td>  
    
</tr>  
    
</c:forEach>  
       
</table>  
</body>  
</html>  

 

student_add.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"  
    pageEncoding
="UTF-8"
%>  
<%@ include file="/include/head.jsp"%>  
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>学生添加</title>  
<mce:script type="text/javascript"><!--   
function turnback(){   
    window.location.href="<%=request.getContextPath() %>/student.do";   
}   
// 
--></mce:script>  
</head>  
<body>  
<form method="post" action="<%=request.getContextPath() %>/student.do?method=save">  
<div><c:out value="${addstate}"></c:out></div>  
<table>  
    
<tr><td>姓名</td><td><input id="user" name="user" type="text" /></td></tr>  
    
<tr><td>密码</td><td><input id="psw" name="psw"  type="text" /></td></tr>  
    
<tr><td colSpan="2" align="center"><input type="submit" value="提交"/><input type="button" onclick="turnback()" value="返回" /> </td></tr>  
</table>  
  
</form>  
</body>  
</html>  

 

controller类实现,只需把注解写上,spring就会自动帮你找到相应的bean,相应的注解标记意义,不明白的,可以自己查下@Service,@Controller,@Entity等等的内容。

package com.mvc.controller;   
  
import java.util.List;   
  
import javax.servlet.http.HttpServletRequest;   
import javax.servlet.http.HttpServletResponse;   
  
import org.apache.commons.logging.Log;   
import org.apache.commons.logging.LogFactory;   
import org.springframework.beans.factory.annotation.Autowired;   
import org.springframework.stereotype.Controller;   
import org.springframework.ui.ModelMap;   
import org.springframework.web.bind.annotation.RequestMapping;   
import org.springframework.web.bind.annotation.RequestMethod;   
import org.springframework.web.bind.annotation.RequestParam;   
import org.springframework.web.servlet.ModelAndView;   
  
import com.mvc.entity.Student;   
import com.mvc.service.StudentService;   
  
@Controller  
@RequestMapping(
"/student.do")   
public class StudentController {   
    
protected final transient Log log = LogFactory   
    .getLog(StudentController.
class);   
    @Autowired  
    
private StudentService studentService;   
    
public StudentController(){   
           
    }
   
       
    @RequestMapping  
    
public String load(ModelMap modelMap){   
        List
<Object> list = studentService.getStudentList();   
        modelMap.put(
"list", list);   
        
return "student";   
    }
   
       
    @RequestMapping(params 
= "method=add")   
    
public String add(HttpServletRequest request, ModelMap modelMap) throws Exception{   
        
return "student_add";   
    }
   
       
    @RequestMapping(params 
= "method=save")   
    
public String save(HttpServletRequest request, ModelMap modelMap){   
        String user 
= request.getParameter("user");   
        String psw 
= request.getParameter("psw");   
        Student st 
= new Student();   
        st.setUser(user);   
        st.setPsw(psw);   
        
try{   
            studentService.save(st);   
            modelMap.put(
"addstate""添加成功");   
        }
   
        
catch(Exception e){   
            log.error(e.getMessage());   
            modelMap.put(
"addstate""添加失败");   
        }
   
           
        
return "student_add";   
    }
   
       
    @RequestMapping(params 
= "method=del")   
    
public void del(@RequestParam("id") String id, HttpServletResponse response){   
        
try{   
            Student st 
= new Student();   
            st.setId(Integer.valueOf(id));   
            studentService.delete(st);   
            response.getWriter().print(
"{\"del\":\"true\"}");   
        }
   
        
catch(Exception e){   
            log.error(e.getMessage());   
            e.printStackTrace();   
        }
   
    }
   
}
  

 

service类实现

package com.mvc.service;   
  
import java.util.List;   
  
import org.springframework.beans.factory.annotation.Autowired;   
import org.springframework.stereotype.Service;   
import org.springframework.transaction.annotation.Transactional;   
  
import com.mvc.dao.EntityDao;   
import com.mvc.entity.Student;   
  
@Service  
public class StudentService {   
 @Autowired  
 
private EntityDao entityDao;   
    
 @Transactional  
 
public List<Object> getStudentList(){   
  StringBuffer sff 
= new StringBuffer();   
  sff.append(
"select a from ").append(Student.class.getSimpleName()).append(" a ");   
  List
<Object> list = entityDao.createQuery(sff.toString());   
  
return list;   
 }
   
    
 
public void save(Student st){   
  entityDao.save(st);   
 }
   
 
public void delete(Object obj){   
  entityDao.delete(obj);   
 }
   
}
 

 

OK,例子写完。有其它业务内容,只需直接新建view,并实现相应comtroller和service就行了,配置和dao层的内容基本不变,也就是每次只需写jsp(view),controller和service调用dao就行了。

怎样,看了这个,spring mvc是不是比ssh实现更方便灵活。

 

 

 

 

 

 

 

 

 

 

 

http://www.blogjava.net/pengo/archive/2010/11/28/339229.html

分享到:
评论

相关推荐

    实验室设备管理系统 SSM毕业设计 附带论文.zip

    实验室设备管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B

    PPT高效插件神器推荐-最新发布.zip

    PPT高效插件神器推荐-最新发布.zip

    数据中心机房基础设计及规划方案.pdf

    数据中心机房是现代信息技术的核心设施,它承载着企业的重要数据和服务,因此,其基础设计与规划至关重要。在制定这样的方案时,需要考虑的因素繁多,包括但不限于以下几点: 1. **容量规划**:必须根据业务需求预测未来几年的数据处理和存储需求,合理规划机房的规模和设备容量。这涉及到服务器的数量、存储设备的容量以及网络带宽的需求等。 2. **电力供应**:数据中心是能源消耗大户,因此电力供应设计是关键。要考虑不间断电源(UPS)、备用发电机的容量,以及高效节能的电力分配系统,确保电力的稳定供应并降低能耗。 3. **冷却系统**:由于设备密集运行,散热问题不容忽视。合理的空调布局和冷却系统设计可以有效控制机房温度,避免设备过热引发故障。 4. **物理安全**:包括防火、防盗、防震、防潮等措施。需要设计防火分区、安装烟雾探测和自动灭火系统,设置访问控制系统,确保只有授权人员能进入。 5. **网络架构**:规划高速、稳定、冗余的网络架构,考虑使用光纤、以太网等技术,构建层次化网络,保证数据传输的高效性和安全性。 6. **运维管理**:设计易于管理和维护的IT基础设施,例如模块化设计便于扩展,集中监控系统可以实时查看设备状态,及时发现并解决问题。 7. **绿色数据中心**:随着环保意识的提升,绿色数据中心成为趋势。采用节能设备,利用自然冷源,以及优化能源管理策略,实现低能耗和低碳排放。 8. **灾难恢复**:考虑备份和恢复策略,建立异地灾备中心,确保在主数据中心发生故障时,业务能够快速恢复。 9. **法规遵从**:需遵循国家和地区的相关法律法规,如信息安全、数据保护和环境保护等,确保数据中心的合法运营。 10. **扩展性**:设计时应考虑到未来的业务发展和技术进步,保证机房有充足的扩展空间和升级能力。 技术创新在数据中心机房基础设计及规划方案中扮演了重要角色。例如,采用虚拟化技术可以提高硬件资源利用率,软件定义网络(SDN)提供更灵活的网络管理,人工智能和机器学习则有助于优化能源管理和故障预测。 总结来说,一个完整且高效的数据中心机房设计及规划方案,不仅需要满足当前的技术需求和业务目标,还需要具备前瞻性和可持续性,以适应快速变化的IT环境和未来可能的技术革新。同时,也要注重经济效益,平衡投资成本与长期运营成本,实现数据中心的高效、安全和绿色运行。

    Visio软件全套资源及教程-最新发布.zip

    Visio软件全套资源及教程-最新发布.zip

    2000-2022年中国地级市生态韧性数据集(含原始数据、计算代码及结果,最新).zip

    2000-2022年中国地级市生态韧性数据集(含原始数据、计算代码及结果,最新).zip

    Spring Cloud 配置相关项目.zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。

    全国2009-2021年农业高质量发展指数测算(重磅,更新!)乡村振兴

    1、资源内容地址:https://blog.csdn.net/abc6838/article/details/143778060 2、数据特点:今年全新,手工精心整理,放心引用,数据来自权威,且标注《数据来源》,相对于其他人的控制变量数据准确很多,适合写论文做实证用 ,不会出现数据造假问题 3、适用对象:大学生,本科生,研究生小白可用,容易上手!!! 4、课程引用: 经济学,地理学,城市规划与城市研究,公共政策与管理,社会学,商业与管理

    Jupyter_这本书被命名为《木星笔记》.zip

    Jupyter-Notebook

    1949-2021年中国民政统计年鉴-最新数据发布.zip

    1949-2021年中国民政统计年鉴-最新数据发布.zip

    Jupyter_用于plot dash的OOP组件,使仪表板组件可组合、可重用和可配置.zip

    Jupyter-Notebook

    Gartner推荐全球4家专注于通过自动化和人工智能支持SOC的优秀供应商.pdf

    Gartner推荐全球4家专注于通过自动化和人工智能支持SOC的优秀供应商.pdf

    Jupyter_AI 常用脚本.zip

    Jupyter-Notebook

    多种 Spring Boot 技术集成示例,涵盖数据持久化、工具集成、功能模块等方面.zip

    1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。

    53朱清清 劳动教育总结报告.doc

    53朱清清 劳动教育总结报告.doc

    Jupyter_CVPR2023强调了一种用于视频预测的动态多尺度体素流网络.zip

    Jupyter-Notebook

    Spss26统计软件最新版-最新发布.zip

    Spss26统计软件最新版-最新发布.zip

    基于springboot mybatis+Mysql 实现的图书管理系统 【web课程设计 】

    【作品名称】:基于springboot mybatis+Mysql 实现的图书管理系统 【web课程设计 】 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 主要功能 登录、注销、修改密码 管理员对图书信息的增删改查、查看读者、查看借阅记录 读者对图书信息的查看查询、修改个人信息、查看借阅记录 使用技术 数据库:mysql5.7 后端框架: SpringBoot HTML模板: ThymeLeaf 持久层: Mybatis UI: Bootstrap 登录验证和用户权限: SpringSecurity 使用说明 本项目使用maven进行管理,详细安装教程自行百度 需下载mysql图形化管理工具(例如Navicat),新建数据库library,右键数据库运行项目中的library.sql脚本 用IDE打开项目(建议使用i 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。

    Python中的动态图形:使用Tkinter绘制跳动的心形

    内容概要:本文详细介绍了用Python的Tkinter库创建动态心脏图形的过程。程序主要由几个部分组成:首先定义了一系列数学函数用于计算心形图的心脏坐标以及散射、收缩效果;然后构建了一个‘BeatingHeart’类来生成不同帧的心跳动画点集;最后,在主函数里调用了这个类的方法绘制出连续的心跳图像,展示了心脏的搏动过程。 适合人群:熟悉Python语言并且对Tkinter库有一定了解的开发者,特别是那些希望利用Python创建图形化应用或者动画模拟的人群。 使用场景及目标:适用于希望快速理解和实现基于Tkinter的基本二维图形与动画制作的学习者或开发者;同时也可以作为图形算法和物理模拟(如粒子系统)的教学案例。 阅读建议:本文涉及到多个函数之间的复杂调用关系,读者需要仔细跟踪每一步操作的具体意义及其参数含义。对于初学者而言,可以先尝试运行示例代码查看实际效果,然后再逐步理解每个部分的功能实现机制。

    宏观面板数据整合(省市区三级)-最新数据.zip

    宏观面板数据整合(省市区三级)-最新数据.zip

    空间计量软件及学习资料-最新更新.zip

    空间计量软件及学习资料-最新更新.zip

Global site tag (gtag.js) - Google Analytics