SpringMVC(一)注解

1.pojo包

2.mapper包

( 注意:这里不需要 IMP 实现类)
包含(mapper和 mapper.xml)

3.Service包

(注意:@Transactional在 serviceIMP 中)

实现类:
@Service
@Transactional
// 该类里面的所有方法或者这个方法的事务由spring处理
// 方法里面对数据库操作,如果失败则spring负责回滚操作,成功提交操作
public class AccountServiceIMP implements AccountService {

    @Resource
    private AccountMapper accountMapper;

    @Override
    public List<Account> queryAccount() {
        return accountMapper.findAll();
    }

4.在 WEB-INF 下建springMVC-servlet.xml

(注意:注意这里是[servlet-name]-servlet.xml,要和web.xml 里面的servlet-name一致)

<?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:context="http://www.springframework.org/schema/context"
【手打mvc 可以跳出来】  xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
【增加context:】
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd 
【增加mvc:】   
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd 
<!-- 1.mvc注解驱动 -->
    <mvc:annotation-driven/>

    <!--2.全局扫描包  -->
    <context:component-scan base-package="com"/>

    <!-- 3.驱动管理数据源 -->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/student"/>
        <property name="username" value="root"/>
        <property name="password" value="123"/>
    </bean>

    <!-- 4.数据源事务管理 -->
    <!-- 开 启 Spring 的 事 务 处 理-->
    <bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

    <!-- 5.sqlsessionfatorybean -->
    <bean id="sqlSessionFactoryBean" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="mapperLocations">
            <value>classpath:com/mapper/*.xml</value>
        </property>
    </bean>

    <!-- 6.spring和mybaits整合:映射输入参数 -->
    <!--MapperFactoryBean作用:注入sqlSessionFactoryBean产出 mapper 实现类-->

    <!--当发现要使用多个MapperFactoryBean,MapperScannerConfigurer类会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。-->
    <!--扫描org.mybatis.spring.sample.mapper下的所有接口,然后创建各自接口的动态代理类-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.mapper"/>
    </bean>

5.web.xml 中

   <servlet>
        <servlet-name>springMVC</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    </servlet>
    <servlet-mapping>
        <servlet-name>springMVC</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

6.Controller

1)@Controller 注解把该class指定为controller
2)@RequestMapping 注解的 value值指定该controller所映射的请求
3)Find方法参数有:HttpServletRequest request,因为是 find 需要携带数据—>return “/index.jsp”—>方法返回值String
4 )update 等方法参数: HttpServletResponse response,因为修改后就不需要携带数据了,且需要重调用 find方法—>重定向 response.sendredirect()—>void
5)注意404错误

@Controller

/* @Controller 注解把该class指定为controller */
@RequestMapping("/account")
public class AccountController {
    @Resource
    private AccountServiceIMP accountServiceImpl;

/* @RequestMapping 注解的 value值指定该controller所映射的请求 */
    @RequestMapping("/findAll.do")
    public String findAll(HttpServletRequest request){
        List<Account> list=accountServiceImpl.queryAccount();
        request.setAttribute("list", list);
        return "/index.jsp";

        // 1. 转发出去,直接到 index.jsp
    }

    @RequestMapping("/findbyid.do")
    public String findById(HttpServletRequest request,Integer id){
        Account account=accountServiceImpl.findById(id);
        request.setAttribute("account", account);
        return "/update.jsp";
    }

    @RequestMapping("/update.do")
    public void editAccount(HttpServletResponse response,Account account) throws IOException{
        Integer num=accountServiceImpl.editAccount(account);
        response.sendRedirect("findAll.do");

        // 2. 重定向到/account/findAll.do
    }
    @RequestMapping("/delbyid.do")
    public void delbyid(HttpServletResponse response,Integer id) throws IOException{
        Integer num = accountServiceImpl.delByid(id);
        response.sendRedirect("findAll.do");
    }

    @RequestMapping("/add.do")
    public void add(HttpServletResponse response,Account account) throws IOException{
        Integer num=accountServiceImpl.add(account);
        response.sendRedirect("findAll.do");
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值