20180302.实现搜索,和搜索后关注用户的功能。

 

首先需要从前端取得用户搜索的信息。双向绑定取得数据,并跳转路径到搜索发现:
this.$http.get('/api/UserManager/Search?s='+this.search1).then((response)=>{

          for(var i in response.data.result){
              sessionStorage.setItem('search'+i,response.data.result[i]);
              sessionStorage.setItem('searchEssay'+i,response.data.result1[i]);
          }
              sessionStorage.setItem('search_times',i);
            }
        )
            .catch(function(err){
              console.log(err);
            });
            //跳转
      this.$router.push({path:'/Child3'});

servlet接受到异步请求后,使用DAO方法:

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp)
        throws ServletException, IOException {

resp.setContentType("text/html;charset=utf-8");

            
    //1. 取到前端发表文章的表单提交的文章信息
            String s = req.getParameter("s");
            
            
            // 再次拿到会话对象
            HttpSession session = req.getSession();
            
            
            ArrayList<essay> List=new UserDAO().search(s);
            
    
    resp.setContentType("application/json");
    // 创建一个json的对象,把结果保存到result键中
    JsonObject result_obj= new JsonObject();
    JsonArray jsonArray=new JsonArray();
    JsonArray jsonArray1=new JsonArray();
    for(int i=0;i<List.size();i++){
        jsonArray.add(List.get(i).getUser_name());
        jsonArray1.add(List.get(i).getContext());
        
    }
    result_obj.add("result",jsonArray);
    result_obj.add("result1",jsonArray1);
    PrintWriter out = resp.getWriter();
    
    // 输出响应结果的时候,以json字符串响应
    out.println(result_obj.toString());
}

后端DAO执行数据库搜索:

@Override

public ArrayList<essay> search(String s) {
    Connection conn=getConnection();
    String sql="";
    PreparedStatement pstmt;
    ArrayList<essay> List=new ArrayList<essay>();
    sql="SELECT * FROM essay WHERE context =? OR user_name =?";
    try{
        pstmt=conn.prepareStatement(sql);
        pstmt.setString(1,s);
        pstmt.setString(2,s);
        ResultSet rs = pstmt.executeQuery();
        while(rs.next()){
            int id=rs.getInt("id");
            String user_name = rs.getString("user_name");
            String context = rs.getString("context");
            Timestamp time=rs.getTimestamp("time");
            List.add(new essay(id,user_name,context,time));
        }
        return List;
    }catch(SQLException e){
        e.printStackTrace();
        return null;
    }finally{
        closeConnection(conn);
    }
}

@Override
public int addFollow(String user_name, String follow_name) {
    Connection conn=getConnection();
    String sql="";
    PreparedStatement pstmt;
    sql="INSERT INTO follow VALUES(?,?)";
    try{
        pstmt=conn.prepareStatement(sql);
        pstmt.setString(1, user_name);
        pstmt.setString(2, follow_name);
        
        return pstmt.executeUpdate();
    }catch(SQLException e){
        e.printStackTrace();
        return 0;
    }finally{
        closeConnection(conn);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值