个人博客

2021年6月15日;

昨天的团队作业新增了一个团员评价的新功能,并且完善了评价之后就不能评价和重新评价的按钮功能,总的来说,团队作业差不多就这样完成了,后天周四就要进行团队作业校验了,至此,历经了一个多月的努力终于把团队作业该做的都做完了。

今天完成了个人作业2的任务,个人作业2是要求做一个热词统计并且爬取某个论文网站的内容进行显示,以下是我的界面:

 

 

 

 这是我的前端代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Layui</title>
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport"
content="width=device-width, initial-scale=1, maximum-scale=1">
<link rel="stylesheet" href="./layui/css/layui.css" media="all">
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js"></script>
<script type="text/javascript" src="./echars/echarts.js"></script>
<script type="text/javascript" src="./echars/echarts-wordcloud.min.js"></script>
<link rel="stylesheet" href="./layui/css/layui.css" media="all">
</head>
<body>
<div id="main" style="width: 100%; height: 250px; display: none;"></div>
<div style="text-align: center;">
<div class="layui-inline">
<table class="layui-hide" id="reci" style="margin: 0 auto;"></table>
</div>
</div>
<div class="layui-form">
<div class="layui-form-item">
<label class="layui-form-label"
style="width: 50px; font-weight: bold;">标题</label>
<div class="layui-input-inline">
<label for="title"></label><input type="text" name="title"
id="title" autocomplete="off" class="layui-input">
</div>
<label class="layui-form-label"
style="width: 50px; font-weight: bold;">关键字</label>
<div class="layui-input-inline">
<label for="keywords"></label><input type="text" name="keywords"
id="keywords" autocomplete="off" class="layui-input">
</div>
<label class="layui-form-label"
style="width: 50px; font-weight: bold;">时间</label>
<div class="layui-input-inline">
<select id="times" name="times">
<option>三年全部</option>
<option value="2020">2020年</option>
<option value="2019">2019年</option>
<option value="2018" selected>2018年</option>
</select>
</div>
<button class="layui-btn layui-btn-normal" onclick="f()"
lay-filter="demo" datatype="reload">搜索</button>
<button class="layui-btn layui-btn-normal" onclick="count()">生成100个热词</button>
</div>
</div>
<table class="layui-hide" id="test" lay-filter="test"></table>
<script type="text/html" id="toolbarDemo">
</script>
<script type="text/html" id="barDemo">
<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
</script>
<script src="./layui/layui.js" charset="utf-8"></script>
<script>
var t_data = null;
function count() {
var m_url = "servlet_count?temp=100";
$
.ajax({
url : m_url,
type : 'post',
dataType : 'json',
contentType : "application/json",
success : function(data1) {
layui.use('table', function() {
var table = layui.table;
table.render({
elem : '#reci',
url : "servlet_count?temp=100",
title : '热词表',
cols : [ [ {
field : 'name',
title : '词名',
width : 150,
edit : 'text'
}, {
field : 'value',
title : '数量',
width : 150
} ] ],
page : false,
defaultToolbar : false,
height : 500,
width : 290,

})
});
$("#main").show();
data = {
value : data1.data,
image : ""
};
var myChart = echarts.init(document
.getElementById('main'));
var maskImage = new Image();
maskImage.src = data.image;
maskImage.onload = function() {
myChart
.setOption({
backgroundColor : '#fff',
tooltip : {
show : false
},
series : [ {
type : 'wordCloud',
gridSize : 1,
sizeRange : [ 12, 55 ],
rotationRange : [ -45, 0, 30,
45, 90 ],
textStyle : {
color : function() {
return 'rgb('
+ Math
.round(Math
.random() * 255)
+ ', '
+ Math
.round(Math
.random() * 255)
+ ', '
+ Math
.round(Math
.random() * 255)
+ ')'
}
},
shape : 'pentagon',
left : 'center',
top : 'center',
right : null,
bottom : null,
data : data.value
} ]
})
};
}
})
}
var table;
layui.use('table', function() {
table = layui.table;
table.render({
elem : '#test',
url : 'servlet',
title : '用户数据表',
cols : [[
{
field : 'title',
title : '标题',
width : 140,
edit : 'text'
},
{
field : 'abstract_text',
title : '摘要',
width : 400
},
{
field : 'original_link',
title : '网址',
width : 400,
templet : function(d) {
return '<a lay-event="edit">'
+ d.original_link + '</a>'
}
}, {
field : 'keywords',
title : '关键字',
width : 500,
}, {
fixed : 'right',
title : '操作',
toolbar : '#barDemo',
width : 70
}]],
page : false,
id : 'testReload',
defaultToolbar : false,
height : 2000
});
table.on('tool(test)', function(obj) {
var data = obj.data;
if (obj.event === 'del') {
layer.confirm('确认删除?', function(index) {
obj.del();
layer.close(index);
});
} else if (obj.event === 'edit') {
window.open(data.original_link)
}
})
});
function f() {
table.reload('testReload', {
url : 'servlets',
where : {
title : document.getElementById('title').value,
keywords : document.getElementById('keywords').value,
times : document.getElementById("times").value
}
})
}
</script>
</body>
</html>

后端代码:

package com.cvpr.servlet;


import com.cvpr.dao.DaoUtil;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet("/servlet_count")
public class servlet_count extends HttpServlet {
/**
*
*/
private static final long serialVersionUID = 1L;

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
resp.setCharacterEncoding("utf-8");
String tempStr = req.getParameter("temp");
int temp = Integer.parseInt(tempStr);
PrintWriter out = resp.getWriter();
String json = DaoUtil.getcount(temp);
json = json.replaceAll("keyword", "name");
json = json.replaceAll("count", "value");
out.print("{\"code\":0,\"msg\":\"\",\"count\":1000,\"data\":"+json+"}");
out.flush();
out.close();
}
}

 

 

package com.cvpr.servlet;

import com.cvpr.dao.DaoUtil;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

//返回全部数据
@WebServlet("/servlet")
public class servlet extends HttpServlet {

/**
*
*/
private static final long serialVersionUID = 1L;
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
String data1="{\"code\":0,\"msg\":\"\",\"count\":1000,\"data\":";
PrintWriter out = resp.getWriter();
out.print(data1+DaoUtil.getData()+"}");
out.flush();
out.close();
}

}

 

package com.cvpr.servlet;

import com.cvpr.bean.search;
import com.cvpr.dao.DaoUtil;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
//返回查询数据

@WebServlet("/servlets")
public class servlets extends HttpServlet {
/**
*
*/
private static final long serialVersionUID = 1L;

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}

@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
resp.setContentType("application/json");
resp.setCharacterEncoding("UTF-8");
String title = req.getParameter("title");
String authors = req.getParameter("authors");
String keywords = req.getParameter("keywords");
String times = req.getParameter("times");
search str = new search(title, authors, keywords, times);
String data1 = "{\"code\":0,\"msg\":\"\",\"count\":1000,\"data\":";
PrintWriter out = resp.getWriter();
out.print(data1 + DaoUtil.getData2(str) + "}");
out.flush();
out.close();
}
}

 

posted @ 2021-06-15 18:41  一条快乐的小鲸鱼  阅读(1024)  评论(0编辑  收藏  举报