springBoot入门和web开发例子

一、SpringBoot的主要优点:

1.快速整合第三方框架,无需配置文件。几乎可以是零配置的开箱即用(out-of-the-box)。开发者能够更加专注于业务逻辑

2.内置http容器(Tomcat、Jetty),最终以java应用程序进行执行

 

二、实现原理:

1.Maven依赖传递

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.0.RELEASE</version>
</parent>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies> 
pom文件引入依赖

2.SpringBoot的Web组件,默认集成的是SpringMVC框架。SpringMVC是控制层。

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
// @EnableAutoConfiguration 作用 开启自动装备(默认是true)
public class IndexController {
    // 1.在微服务情况,基本上都在类上加上@RestController 目的?返回json格式。
//2.@RestController注解相当于@ResponseBody + @Controller合在一起的作用。如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,或者html,配置的视图解析器 InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。使用传统方式返回json
//@RestController 修饰的类下的所有方法,全部都是返回josn格式,这样的话不用在方法上加上@ResponseBody @RequestMapping("/index1") public String index() throws InterruptedException { return "v6.0"; } // // 思考:如何启动? 使用main启动 // public static void main(String[] args) { // // 告诉SpringBoot 程序入口 默认端口号是8080 // SpringApplication.run(IndexController.class, args); // } }

 

3.内置Tomcat tomcat = new Tomcat() 对象

@RestController
@EnableAutoConfiguration
public class HelloController {
    @RequestMapping("/hello")
    public String index() {
        return "Hello World";
    }    
public static void main(String[] args) {
        SpringApplication.run(HelloController.class, args);
    }
}
tomcat启动main方法

三、StringMVC

@Controller:表示这个类是SpringMVC 里的Controller,DispatchServlet会自动扫面这个类。效果:用这个注解,通过return的String类型的数据,视图解析器可以解析jsp,html页面,并且跳转到相应页面。目的就是为了能访问,所以是必须的。

@ResponseBody :可作用于类或者方法,表示该方法的返回结果直接写入 HTTP response body 中,适用于返回JSON,XML。无法返回jsp页面,或者html。一般通过Ajax程序来获取数据。一般只写在方法上面,因为这个注解是为了,区别同一个类,不同的方法到底是返回页面还是返回数据!

@RestController: 表示 Controller+ ResponseBody(类上只用ResponseBody是不能被访问的,必须要有Controller),同样不能返回jsp和html。如果是只用于返回json的类,一般用这种。

@RequestMapping(“/url”):作用在 Controller的方法,表示映射地址

 四、实践

  资源访问

  Springboot 的工作目录resources下面有两个文件夹,static 和 templates。

1.Static 文件夹下面放静态资源

可以直接访问(默认页面index.html)可以用浏览器直接访问,localhost:81默认页面 为 static/index.html。

         http://localhost:81/images/aa.jpg http://localhost:81/aa.html

2.templates 文件夹下面放动态页面(使用Freemarker模板引擎渲染web视图)

           <dependency> 

               <groupId>org.springframework.boot</groupId> 

               <artifactId>spring-boot-starter-thymeleaf</artifactId> 

           </dependency>
View Code

加入thymeleaf依赖,就可以通过java代码转发到目录下面的页面。

Java代码如下:

@Controller //表示转发到页面
public class TTController {
    @RequestMapping("/test")
    public String test() {
        return "test";//访问的是templates下面的test.html
    }    
}

 

下面是动态页面演示:

 

java代码

@Controller
public class TextController {
    
    @Autowired
    private TextServiceImpl textServiceImpl;

    @RequestMapping("/text")
    public String text(Model model,HttpServletRequest request){
        List<Text> textList = textServiceImpl.findAll();
        model.addAttribute("textList",textList);
        return "text";
    }    
    @RequestMapping("/insert")
    public String insert(String content,Model model,HttpServletRequest request){
        Text text = new Text();
        text.setContent(content);
        Integer i = textServiceImpl.insert(text);
        if(i==1){
            System.out.println("插入成功");
        }
        List<Text> textList = textServiceImpl.findAll();
        model.addAttribute("textList",textList);
        return "text";
    }
}

@Service //自动注册到Spring容器,不需要再在applicationContext.xml配置
public class TextServiceImpl implements TextService{
    
    @Autowired
    private TextMapper textMapper;

    public List<Text> findAll(){
        return textMapper.findAll();
    }
    @Transactional 
    public Integer insert(Text text) {
        int insertResult = textMapper.insert(text.getContent());
        System.out.println("insertResult="+insertResult);
        return insertResult;
    }
}
public interface TextService {
    
    public Integer insert(Text text);
    public List<Text> findAll();

}
@Repository //用于标注数据访问组件
public interface TextMapper {
    
    @Select("SELECT * FROM TEXT")
    List<Text> findAll();

/*    @Select("SELECT * FROM USER WHERE NAME = #{name}")
    User findByName(@Param("name") String name);
*/
    @Insert("INSERT INTO TEXT (content) VALUE(#{content})")
    int insert(@Param("content") String content);

}

 

src\main\resources\templates\text.html

 

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8">
    <title>文本显示</title>
    <script type="text/javascript"></script>
<body >

<form action="/insert">

文字:<input type="text" name="content"/>
<input type="submit" value="提交">

</form>

<thead>
    <tr th:each="text:${textList}">
        <td th:text="${text.content}"></td>        
    </tr>
     </thead>
</body>
</html>

 main方法

//@EnableAutoConfiguration 作用在于让 Spring Boot   根据应用所声明的依赖来对 Spring 框架进行自动配置
//@ComponentScan(basePackages = "wull.tool.*") 控制器扫包范围
@SpringBootApplication //这个表示上面两行 //@ComponentScan("/")
@MapperScan("wull.*")

public class ToolApplication {
    public static void main(String[] args)
    {
        SpringApplication.run(ToolApplication.class, args);
        System.out.println("启动成功" );
    }
}

 

 

 

 

 

 

 

 

 

posted @ 2019-06-07 21:30  wullll  阅读(5017)  评论(0编辑  收藏