基于javaweb+mysql的jsp+servlet新闻发布管理系统(java+jsp+servlet+mysql)
运行环境
Java≥8、MySQL≥5.7、Tomcat≥8
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
后台:管理新闻类型、新闻、评论、链接
前台:看新闻、评论
后台
前台
技术框架
JSP Servlet MySQL JDBC Tomcat jQuery Bootstrap JavaScript
基于javaweb+mysql的JSP+Servlet新闻发布管理系统(java+jsp+servlet+mysql)
}
private void linkBackList(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException{
Connection con=null;
try{
con=dbUtil.getCon();
List<Link> linkBackList=linkDao.linkList(con, "select * from t_link order by orderNum");
request.setAttribute("linkBackList", linkBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("友情链接管理", "友情链接维护"));
request.setAttribute("mainPage", "/background/link/linkList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void linkPreSave(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException{
String linkId=request.getParameter("linkId");
Connection con=null;
try{
con=dbUtil.getCon();
if(StringUtil.isNotEmpty(linkId)){
Link link=linkDao.getLinkById(con, linkId);
request.setAttribute("link", link);
}
if(StringUtil.isNotEmpty(linkId)){
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("友情链接管理", "友情链接修改"));
}else{
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("友情链接管理", "友情链接添加"));
}
request.setAttribute("mainPage", "/background/link/linkSave.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
throws ServletException, IOException {
String s_bCommentDate=request.getParameter("s_bCommentDate");
String s_aCommentDate=request.getParameter("s_aCommentDate");
String page=request.getParameter("page");
HttpSession session=request.getSession();
if(StringUtil.isEmpty(page)){
page="1";
session.setAttribute("s_bCommentDate", s_bCommentDate);
session.setAttribute("s_aCommentDate", s_aCommentDate);
}else{
s_bCommentDate=(String) session.getAttribute("s_bCommentDate");
s_aCommentDate=(String) session.getAttribute("s_aCommentDate");
}
Connection con=null;
try{
con=dbUtil.getCon();
int total=commentDao.commentCount(con, new Comment(), s_bCommentDate, s_aCommentDate);
String pageCode=PageUtil.getPagation(request.getContextPath()+"/comment?action=backList", total, Integer.parseInt(page), Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
List<Comment> commentBackList=commentDao.commentList(con, new Comment(),pageBean,s_bCommentDate,s_aCommentDate);
request.setAttribute("pageCode", pageCode);
request.setAttribute("commentBackList", commentBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("新闻评论管理", "新闻评论维护"));
request.setAttribute("mainPage", "/background/comment/commentList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void commentDelete(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String commentIds=request.getParameter("commentIds");
Connection con=null;
try{
con=dbUtil.getCon();
JSONObject result=new JSONObject();
int delNums=commentDao.commentDelete(con, commentIds);
if(delNums>0){
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
NewsDao newsDao=new NewsDao();
NewsTypeDao newsTypeDao=new NewsTypeDao();
CommentDao commentDao=new CommentDao();
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
String action=request.getParameter("action");
if("list".equals(action)){
this.newsList(request, response);
}else if("show".equals(action)){
this.newsShow(request, response);
}else if("preSave".equals(action)){
this.newsPreSave(request, response);
}else if("save".equals(action)){
this.newsSave(request, response);
}else if("backList".equals(action)){
this.newsBackList(request,response);
}else if("delete".equals(action)){
this.newsDelete(request,response);
}
}
private void newsList(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String typeId=request.getParameter("typeId");
String page=request.getParameter("page");
if(StringUtil.isEmpty(page)){
page="1";
}
Connection con=null;
News s_news=new News();
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void newsShow(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String newsId=request.getParameter("newsId");
Connection con=null;
try{
con=dbUtil.getCon();
newsDao.newsClick(con, newsId);
News news=newsDao.getNewsById(con, newsId);
Comment s_comment=new Comment();
s_comment.setNewsId(Integer.parseInt(newsId));
List<Comment> commentList=commentDao.commentList(con, s_comment,null,null,null);
request.setAttribute("commentList", commentList);
request.setAttribute("news", news);
request.setAttribute("pageCode", this.genUpAndDownPageCode(newsDao.getUpAndDownPageId(con, newsId)));
request.setAttribute("navCode", NavUtil.genNewsNavigation(news.getTypeName(), news.getTypeId()+"",news.getTitle()));
request.setAttribute("title", news.getTitle());
request.setAttribute("mainPage", "news/newsShow.jsp");
request.getRequestDispatcher("foreground/newsTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private String genUpAndDownPageCode(List<News> upAndDownPage){
News upNews=upAndDownPage.get(0);
News downNews=upAndDownPage.get(1);
StringBuffer pageCode=new StringBuffer();
if(upNews.getNewsId()==-1){
pageCode.append("<p>上一篇:没有了</p>");
}else{
pageCode.append("<p>上一篇:<a href='news?action=show&newsId="+upNews.getNewsId()+"'>"+upNews.getTitle()+"</a></p>");
}
if(downNews.getNewsId()==-1){
pageCode.append("<p>下一篇:没有了</p>");
}else{
pageCode.append("<p>下一篇:<a href='news?action=show&newsId="+downNews.getNewsId()+"'>"+downNews.getTitle()+"</a></p>");
}
return pageCode.toString();
throws ServletException, IOException {
Connection con=null;
try{
con=dbUtil.getCon();
List<NewsType> newsTypeBackList=newsTypeDao.newsTypeList(con);
request.setAttribute("newsTypeBackList", newsTypeBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("新闻类别管理", "新闻类别维护"));
request.setAttribute("mainPage", "/background/newsType/newsTypeList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void newsTypeDelete(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String newsTypeId=request.getParameter("newsTypeId");
Connection con=null;
try{
con=dbUtil.getCon();
JSONObject result=new JSONObject();
boolean exist=newsDao.existNewsWithNewsTypeId(con, newsTypeId);
if(exist){
result.put("errorMsg", "该新闻类别下有新闻,不能删除此新闻类别");
}else{
int delNums=newsTypeDao.newsTypeDelete(con, newsTypeId);
if(delNums>0){
result.put("success", true);
}else{
result.put("errorMsg", "删除失败");
}
}
ResponseUtil.write(result, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
sql="select * from t_news order by click desc limit 0,8";
List<News> hotNewsList=newsDao.newsList(con, sql);
application.setAttribute("hotNewsList", hotNewsList);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
HttpSession session=request.getSession();
ServletContext application=session.getServletContext();
this.refreshSystem(application);
JSONObject result=new JSONObject();
result.put("success", true);
try {
ResponseUtil.write(result, response);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class ResponseUtil {
public static void write(Object o,HttpServletResponse response)throws Exception{
response.setContentType("text/html;charset=utf-8");
public class InitServlet extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
NewsDao newsDao=new NewsDao();
NewsTypeDao newsTypeDao=new NewsTypeDao();
@Override
public void init(ServletConfig config) throws ServletException {
ServletContext application=config.getServletContext();
this.refreshSystem(application);
}
private void refreshSystem(ServletContext application){
Connection con=null;
try{
con=dbUtil.getCon();
List<NewsType> newsTypeList=newsTypeDao.newsTypeList(con);
throws ServletException, IOException {
String s_bPublishDate=request.getParameter("s_bPublishDate");
String s_aPublishDate=request.getParameter("s_aPublishDate");
String s_title=request.getParameter("s_title");
String page=request.getParameter("page");
HttpSession session=request.getSession();
if(StringUtil.isEmpty(page)){
page="1";
session.setAttribute("s_bPublishDate", s_bPublishDate);
session.setAttribute("s_aPublishDate", s_aPublishDate);
session.setAttribute("s_title", s_title);
}else{
s_bPublishDate=(String) session.getAttribute("s_bPublishDate");
s_aPublishDate=(String) session.getAttribute("s_aPublishDate");
s_title=(String) session.getAttribute("s_title");
}
Connection con=null;
News s_news=new News();
if(StringUtil.isNotEmpty(s_title)){
s_news.setTitle(s_title);
}
try{
con=dbUtil.getCon();
int total=newsDao.newsCount(con, s_news, s_bPublishDate, s_aPublishDate);
String pageCode=PageUtil.getPagation(request.getContextPath()+"/news?action=backList", total, Integer.parseInt(page), Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
List<News> newsBackList=newsDao.newsList(con, s_news,pageBean,s_bPublishDate,s_aPublishDate);
request.setAttribute("pageCode", pageCode);
request.setAttribute("newsBackList", newsBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("新闻管理", "新闻列表"));
request.setAttribute("mainPage", "/background/news/newsList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void newsDelete(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException{
String newsId=request.getParameter("newsId");
Connection con=null;
boolean delFlag;
public class NewsTypeServlet extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
NewsDao newsDao=new NewsDao();
NewsTypeDao newsTypeDao=new NewsTypeDao();
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
String action=request.getParameter("action");
if("preSave".equals(action)){
this.newsTypePreSave(request, response);
}else if("save".equals(action)){
this.newsTypeSave(request, response);
}else if("backList".equals(action)){
this.newsTypeBackList(request, response);
}else if("delete".equals(action)){
this.newsTypeDelete(request, response);
}
}
private void newsTypePreSave(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String newsTypeId=request.getParameter("newsTypeId");
Connection con=null;
try{
con=dbUtil.getCon();
if(StringUtil.isNotEmpty(newsTypeId)){
HttpSession session=request.getSession();
if(StringUtil.isEmpty(page)){
page="1";
session.setAttribute("s_bPublishDate", s_bPublishDate);
session.setAttribute("s_aPublishDate", s_aPublishDate);
session.setAttribute("s_title", s_title);
}else{
s_bPublishDate=(String) session.getAttribute("s_bPublishDate");
s_aPublishDate=(String) session.getAttribute("s_aPublishDate");
s_title=(String) session.getAttribute("s_title");
}
Connection con=null;
News s_news=new News();
if(StringUtil.isNotEmpty(s_title)){
s_news.setTitle(s_title);
}
try{
con=dbUtil.getCon();
int total=newsDao.newsCount(con, s_news, s_bPublishDate, s_aPublishDate);
String pageCode=PageUtil.getPagation(request.getContextPath()+"/news?action=backList", total, Integer.parseInt(page), Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
List<News> newsBackList=newsDao.newsList(con, s_news,pageBean,s_bPublishDate,s_aPublishDate);
request.setAttribute("pageCode", pageCode);
request.setAttribute("newsBackList", newsBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("新闻管理", "新闻列表"));
request.setAttribute("mainPage", "/background/news/newsList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void newsDelete(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException{
String newsId=request.getParameter("newsId");
try {
List<FileItem> list = upload.parseRequest(request);
for (FileItem fileItem : list) {
String imageName = DateUtil.getCurrentDateStr();
File file = new File(PropertiesUtil.getValue("imagePath") + imageName + "." + fileItem.getName().split("\\.")[1]);
String newPath = PropertiesUtil.getValue("imageFile") + "/" + imageName + "." + fileItem.getName().split("\\.")[1];
fileItem.write(file);
String callback = request.getParameter("CKEditorFuncNum");
out.println("<script type=\"text/javascript\">");
out.println("window.parent.CKEDITOR.tools.callFunction(" + callback + ",'" + newPath + "',''" + ")");
out.println("</script>");
out.flush();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class UserServlet extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
application.setAttribute("newestNewsList", newestNewsList);
sql="select * from t_news order by click desc limit 0,8";
List<News> hotNewsList=newsDao.newsList(con, sql);
application.setAttribute("hotNewsList", hotNewsList);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
HttpSession session=request.getSession();
ServletContext application=session.getServletContext();
this.refreshSystem(application);
JSONObject result=new JSONObject();
result.put("success", true);
try {
ResponseUtil.write(result, response);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class ResponseUtil {
public static void write(Object o,HttpServletResponse response)throws Exception{
response.setContentType("text/html;charset=utf-8");
PrintWriter out=response.getWriter();
/**
*
*/
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
CommentDao commentDao=new CommentDao();
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
String action=request.getParameter("action");
if("save".equals(action)){
commentSave(request,response);
}else if("backList".equals(action)){
commentBackList(request,response);
}else if("delete".equals(action)){
commentDelete(request,response);
}
}
private void commentSave(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String newsId=request.getParameter("newsId");
String content=request.getParameter("content");
String userIP=request.getRemoteAddr();
Comment comment=new Comment(Integer.parseInt(newsId), content, userIP);
Connection con=null;
try{
con=dbUtil.getCon();
commentDao.commentAdd(con, comment);
request.getRequestDispatcher("news?action=show&newsId="+newsId).forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
System.out.println("图片目录:" + realPath);
System.out.println("图片目录:" + realPath);
System.out.println("图片目录:" + realPath);
System.out.println("图片目录:" + realPath);
System.out.println("图片目录:" + realPath);
try {
List<FileItem> list = upload.parseRequest(request);
for (FileItem fileItem : list) {
String imageName = DateUtil.getCurrentDateStr();
File file = new File(PropertiesUtil.getValue("imagePath") + imageName + "." + fileItem.getName().split("\\.")[1]);
String newPath = PropertiesUtil.getValue("imageFile") + "/" + imageName + "." + fileItem.getName().split("\\.")[1];
fileItem.write(file);
String callback = request.getParameter("CKEditorFuncNum");
out.println("<script type=\"text/javascript\">");
out.println("window.parent.CKEDITOR.tools.callFunction(" + callback + ",'" + newPath + "',''" + ")");
out.println("</script>");
out.flush();
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
public class UserServlet extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
UserDao userDao=new UserDao();
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setAttribute("headNews", headNews);
sql="select * from t_news where isHot=1 order by publishDate desc limit 0,8 ";
List<News> hotSpotNewsList=newsDao.newsList(con, sql);
request.setAttribute("hotSpotNewsList", hotSpotNewsList);
List allIndexNewsList=new ArrayList();
if(newsTypeList!=null && newsTypeList.size()!=0){
for(int i=0;i<newsTypeList.size();i++){
NewsType newsType=newsTypeList.get(i);
sql="select * from t_news,t_newsType where typeId=newsTypeId and typeId="+newsType.getNewsTypeId()+" order by publishDate desc limit 0,8";
List<News> oneSubList=newsDao.newsList(con, sql);
allIndexNewsList.add(oneSubList);
}
}
request.setAttribute("allIndexNewsList", allIndexNewsList);
sql="select * from t_link order by orderNum ";
List<Link> linkList=linkDao.linkList(con, sql);
request.setAttribute("linkList", linkList);
request.getRequestDispatcher("index.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
commentDao.commentAdd(con, comment);
request.getRequestDispatcher("news?action=show&newsId="+newsId).forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
private void commentBackList(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String s_bCommentDate=request.getParameter("s_bCommentDate");
String s_aCommentDate=request.getParameter("s_aCommentDate");
String page=request.getParameter("page");
HttpSession session=request.getSession();
if(StringUtil.isEmpty(page)){
page="1";
session.setAttribute("s_bCommentDate", s_bCommentDate);
session.setAttribute("s_aCommentDate", s_aCommentDate);
}else{
s_bCommentDate=(String) session.getAttribute("s_bCommentDate");
s_aCommentDate=(String) session.getAttribute("s_aCommentDate");
}
Connection con=null;
try{
con=dbUtil.getCon();
int total=commentDao.commentCount(con, new Comment(), s_bCommentDate, s_aCommentDate);
String pageCode=PageUtil.getPagation(request.getContextPath()+"/comment?action=backList", total, Integer.parseInt(page), Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
PageBean pageBean=new PageBean(Integer.parseInt(page),Integer.parseInt(PropertiesUtil.getValue("backPageSize")));
List<Comment> commentBackList=commentDao.commentList(con, new Comment(),pageBean,s_bCommentDate,s_aCommentDate);
request.setAttribute("pageCode", pageCode);
request.setAttribute("commentBackList", commentBackList);
request.setAttribute("navCode", NavUtil.genNewsManageNavigation("新闻评论管理", "新闻评论维护"));
request.setAttribute("mainPage", "/background/comment/commentList.jsp");
request.getRequestDispatcher("/background/mainTemp.jsp").forward(request, response);
}catch(Exception e){
e.printStackTrace();
}finally{
try {
dbUtil.closeCon(con);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
public class IndexServlet extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
DbUtil dbUtil=new DbUtil();
NewsDao newsDao=new NewsDao();
NewsTypeDao newsTypeDao=new NewsTypeDao();
LinkDao linkDao=new LinkDao();
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
this.doPost(request, response);
}
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
Connection con=null;
try{
con=dbUtil.getCon();
List<NewsType> newsTypeList=newsTypeDao.newsTypeList(con);
String sql="select * from t_news where isImage=1 order by publishDate desc limit 0,5";
List<News> imageNewsList=newsDao.newsList(con, sql);
request.setAttribute("imageNewsList", imageNewsList);
sql="select * from t_news where isHead=1 order by publishDate desc limit 0,1 ";
List<News> headNewsList=newsDao.newsList(con, sql);