新聞管理系統的首頁功能
- 資訊展示
- 搜尋新聞
- 新聞跳轉
檢視靜态資源裡的首頁界面,需要實作首頁展示分類、标簽、新聞和推薦新聞功能和點選新聞進入相應的新聞檢視界面功能
![](https://img.laitimes.com/img/__Qf2AjLwojIjJCLyojI0JCLiAzNfRHLGZkRGZkRfJ3bs92YsYTMfVmepNHLysmeNJTV65UeRpHW4Z0MMBjVtJWd0ckW65UbM5WOHJWa5kHT20ESjBjUIF2X0hXZ0xCMx81dvRWYoNHLrdEZwZ1Rh5WNXp1bwNjW1ZUba9VZwlHdssmch1mclRXY39CXldWYtlWPzNXZj9mcw1ycz9WL49zZuBnLykjM3IDMycTMwMzNwAjMwIzLc52YucWbp5GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.png)
資訊展示
首頁展示使用web目錄下的indexController,檢視靜态界面我們一共需要四個部分的展示功能,分别是
1. 新聞展示
在這裡我們需要提取到資料庫中的所有新聞資訊,然後進行分頁展示,首先先在NewService接口中聲明一個分頁查詢的方法
//首頁分頁展示
Page<News> listNew(Pageable pageable);
再在Impl中實作該方法,直接使用jpa中根據分頁查詢的方法
@Override
public Page<News> listNew(Pageable pageable) {
return newRepository.findAll(pageable);
}
最後再在indexController中調用該方法顯示
@Controller
public class indexController {
@Autowired
private NewService newService;
@GetMapping("/")
public String index(@PageableDefault(size = 3,sort = {"updateTime"},direction = Sort.Direction.DESC)
Pageable pageable, Model model){
model.addAttribute("page",newService.listNew(pageable));
return "index";
}
}
2. 分類展示
這裡我們自定義一個查詢資料庫方法,在typeRepository中聲明一個查詢type方法,其他部分和新聞展示一樣,需要先在TypeService中聲明一個接口方法,分類不需要分頁,隻需要展示出固定幾條分類m是以設計為以下即可,size表示展示的資料量
@Query("select t from Type t")
List<Type> findTop(Pageable pageable);
//不分頁的List 在查找新聞界面顯示出
List<Type> listTypeTop(Integer size);
Impl中實作該方法,根據分類下的新聞數量進行排序
//顯示在首頁
@Override
public List<Type> listTypeTop(Integer size) {
Sort sort = Sort.by(Sort.Direction.DESC,"news.size");
Pageable pageable = PageRequest.of(0,size,sort);
return typeRepository.findTop(pageable);
}
最後再在indexController中添加該方法顯示
@Controller
public class indexController {
@Autowired
private NewService newService;
@Autowired
private TypeService typeService;
@GetMapping("/")
public String index(@PageableDefault(size = 3,sort = {"updateTime"},direction = Sort.Direction.DESC)
Pageable pageable, Model model){
model.addAttribute("page",newService.listNew(pageable));
model.addAttribute("types",typeService.listTypeTop(3));
return "index";
}
}
3. 标簽展示
标簽顯示和分類顯示是一樣的,先在TagRepository下聲明一個查詢資料庫的方法,再在Service中聲明接口和實作接口方法,同樣按照标簽下新聞數量進行排序,最後添加到controller中
TagRepository
@Query("select t from Tag t")
List<Tag> findTop(Pageable pageable);
TagService
//顯示在首頁
List<Tag> listTagTop(Integer size);
TagServiceImpl
@Override
public List<Tag> listTagTop(Integer size) {
Sort sort = Sort.by(Sort.Direction.DESC,"newsList.size");
Pageable pageable = PageRequest.of(0,size,sort);
return tagRepository.findTop(pageable);
}
indexController
@Controller
public class indexController {
@Autowired
private TypeService typeService;
@Autowired
private TagService tagService;
@Autowired
private NewService newService;
@GetMapping("/")
public String index(@PageableDefault(size = 3,sort = {"updateTime"},direction = Sort.Direction.DESC)
Pageable pageable, Model model){
model.addAttribute("page",newService.listNew(pageable));
model.addAttribute("types",typeService.listTypeTop(3));
model.addAttribute("tags",tagService.listTagTop(3));
return "index";
}
}
4. 推薦新聞展示
和前面一樣,不過sql語句需要更換查詢條件
NewRepository
@Query("select n from News n where n.recommend = true")
List<News> findTop(Pageable pageable);
NewService
//首頁推薦最新新聞
List<News> listRecommendNewTop(Integer size);
NewServiceImpl
@Override
public List<News> listRecommendNewTop(Integer size) {
Sort sort = Sort.by(Sort.Direction.DESC,"updateTime");
Pageable pageable = PageRequest.of(0,size,sort);
return newRepository.findTop(pageable);
}
indexController
@Controller
public class indexController {
@Autowired
private TypeService typeService;
@Autowired
private TagService tagService;
@Autowired
private NewService newService;
@GetMapping("/")
public String index(@PageableDefault(size = 3,sort = {"updateTime"},direction = Sort.Direction.DESC)
Pageable pageable, Model model){
model.addAttribute("page",newService.listNew(pageable));
model.addAttribute("types",typeService.listTypeTop(3));
model.addAttribute("tags",tagService.listTagTop(3));
model.addAttribute("recommendNews",newService.listRecommendNewTop(3));
return "index";
}
}
搜尋新聞
在首頁顯示新聞之後,右上角有一個搜尋新聞功能,可以根據文章标題和文章内容進行模糊搜尋
首先在NewRepository中聲明接口方法自定義sql語句進行查詢
// //輸入标題或文本内容查詢
@Query("select n from News n where n.title like ?1 or n.content like ?1")
Page<News> findByQuery(String query, Pageable pageable);
再在NewService中聲明模糊查詢接口方法
//全局搜尋
Page<News> listNew(String query,Pageable pageable);
實作方法
@Override
public Page<News> listNew(String query, Pageable pageable) {
return newRepository.findByQuery(query,pageable);
}
在indexController添加該方法
//搜尋
@PostMapping("/search")
public String search(@PageableDefault(size = 3,sort = {"updateTime"},direction = Sort.Direction.DESC)Pageable pageable,
@RequestParam String query,Model model){
model.addAttribute("page",newService.listNew("%"+query+"%",pageable));
model.addAttribute("query",query);
return "search";
}
新聞跳轉
點選顯示的新聞,跳轉到相應的新聞顯示界面,這裡隻需要用到根據id查詢新聞功能,用不到其餘的資料庫查詢方法,是以不用新聲明資料庫接口方法,直接使用jpa中給的findById,在NewService中聲明一個方法
//擷取新聞跳轉
News getAndConvert(Long id);
Impl中實作,因為新聞需要展示文本資訊,是以我們需要将存在資料庫的content轉換為md模式,需要用到一個工具類MarkDownUtils,建立一個Util檔案夾,建立MarkDownUtils.java
package com.tengshan.springpro.util;
import org.commonmark.Extension;
import org.commonmark.ext.gfm.tables.TableBlock;
import org.commonmark.ext.gfm.tables.TablesExtension;
import org.commonmark.ext.heading.anchor.HeadingAnchorExtension;
import org.commonmark.node.Link;
import org.commonmark.node.Node;
import org.commonmark.parser.Parser;
import org.commonmark.renderer.html.AttributeProvider;
import org.commonmark.renderer.html.AttributeProviderContext;
import org.commonmark.renderer.html.AttributeProviderFactory;
import org.commonmark.renderer.html.HtmlRenderer;
import java.util.*;
public class MarkdownUtils {
/**
* markdown格式轉換成HTML格式
* @param markdown
* @return
*/
public static String markdownToHtml(String markdown) {
Parser parser = Parser.builder().build();
Node document = parser.parse(markdown);
HtmlRenderer renderer = HtmlRenderer.builder().build();
return renderer.render(document);
}
/**
* 增加擴充[标題錨點,表格生成]
* Markdown轉換成HTML
* @param markdown
* @return
*/
public static String markdownToHtmlExtensions(String markdown) {
//h标題生成id
Set<Extension> headingAnchorExtensions = Collections.singleton(HeadingAnchorExtension.create());
//轉換table的HTML
List<Extension> tableExtension = Arrays.asList(TablesExtension.create());
Parser parser = Parser.builder()
.extensions(tableExtension)
.build();
Node document = parser.parse(markdown);
HtmlRenderer renderer = HtmlRenderer.builder()
.extensions(headingAnchorExtensions)
.extensions(tableExtension)
.attributeProviderFactory(new AttributeProviderFactory() {
public AttributeProvider create(AttributeProviderContext context) {
return new CustomAttributeProvider();
}
})
.build();
return renderer.render(document);
}
/**
* 處理标簽的屬性
*/
static class CustomAttributeProvider implements AttributeProvider {
@Override
public void setAttributes(Node node, String tagName, Map<String, String> attributes) {
//改變a标簽的target屬性為_blank
if (node instanceof Link) {
attributes.put("target", "_blank");
}
if (node instanceof TableBlock) {
attributes.put("class", "ui celled table");
}
}
}
public static void main(String[] args) {
String table = "| hello | hi | 哈哈哈 |\n" +
"| ----- | ---- | ----- |\n" +
"| 斯維爾多 | 士大夫 | f啊 |\n" +
"| 阿什頓發 | 非固定杆 | 撒阿什頓發 |\n" +
"\n";
String a = "[imCoding 愛程式設計](http://www.lirenmi.cn)";
System.out.println(markdownToHtmlExtensions(a));
}
}
NewServiceImpl
@Override
public News getAndConvert(Long id) {
News news = newRepository.findById(id).orElse(null);
if(news==null){
System.out.println("該新聞不存在");
}
News news1 = new News();
BeanUtils.copyProperties(news,news1);
String content = news1.getContent();
news1.setContent(MarkdownUtils.markdownToHtmlExtensions(content));
return news1;
}
最後在indexController中實作
//展示點選的新聞
@RequestMapping("/news/{id}")
public String news(@PathVariable Long id,Model model){
News news = newService.getAndConvert(id);
model.addAttribute("news",news);
return "new";
}
效果展示: