会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133542个问题
JAVA 全系列/第十一阶段:分布式RPC调用和分布式文件存储/Dubbo 30331楼
人工智能/第六阶段:机器学习-线性分类/SVM支持向量机算法 30332楼
Python 全系列/第六阶段:数据库与AI协同技术实战/mysql的使用 30334楼
WEB前端全系列/第五阶段:前后端交互/网络请求AJAX 30337楼
Python 全系列/第八阶段:Web全栈开发基础与前端/HTML5 30338楼

老师,我这里的返回信息,还是出现乱码。这个编码格式设置应该在哪里定义或修改?

返回信息:

图片.png

源码:

response类:

package Server;

import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;

import Util.IOCloseUtil;

/**
 *响应类
 */
public class Response {//响应
    private StringBuilder headInfo;//响应头
    private StringBuilder content;//响应内容
    private int length;//响应内容的长度
    private BufferedWriter bw;//流
    
    //两个常量、换行、空格
    private static final String CRLF="\r\n";//换行
    private static final String BLANK=" ";//空格
    
    
    //构造方法
    public Response() {
        headInfo=new StringBuilder();
        content=new StringBuilder();
    }
    
    
    //带参构造方法获得输出流
    public Response(OutputStream os) {
        this();//调用本类的无参构造方法,由于初始化变量
        try {
            bw=new BufferedWriter(new OutputStreamWriter(os,"utf-8"));
        } catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    
    
    //构造正文部分,传什么就向content中添加什么,此方法不换行
    public Response print(String info) {
        content.append(info);
        try {
            length+=info.getBytes("utf-8").length;
        } catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return this;
    }
    
    
    //构造正文部分,此方法换行
    public Response println(String info) {
        content.append(info).append(CRLF);
        try {
            length+=(info+CRLF).getBytes("utf-8").length;
        } catch (UnsupportedEncodingException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return this;
    }
    
    
    //构造响应头
    private void createHeadInfo(int code) {
        headInfo.append("HTTP/1.1").append(BLANK).append(code).append(BLANK);
        //状态码信息描述
        switch (code) {
        case 200:
            headInfo.append("OK");
            break;
        case 500:
            headInfo.append("SERVER ERROR");
            break;
        default:
            headInfo.append("NOT FOUND");
            break;
        }
        headInfo.append(CRLF);
        headInfo.append("Content-Type:text/html;charst=utf-8").append(CRLF);
        headInfo.append("Content-Length:"+length).append(CRLF);
        headInfo.append(CRLF);    
    }
    
    
    /**
     * 推送到浏览器端
     */
    public void pushToClient(int code) {
        if(headInfo==null) {
            code=500;
        }
        //调用本类的构造方法
        this.createHeadInfo(code);
        try {
            bw.write(headInfo.toString());
            bw.write(content.toString());
            bw.flush();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        IOCloseUtil.closeAll(bw);//关闭语句
        
    }
    
}

server类:

package Server;

import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.ServerSocket;
import java.net.Socket;

import Servlet.Servlet;
import Util.IOCloseUtil;

/**
 *服务器类,用于启动、停止服务
 */
public class Server {
    private ServerSocket server;
    
    public static void main(String[] args) {
        Server server=new Server();//创建服务器对象
        server.start();
    }
    
    public void start() {
            this.start(8888);    
    }
    
    public void start(int port) {
        
        try {
            server=new ServerSocket(port);
            this.receive(); //调用接收请求信息的方法
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    
    }
    
    //调用接收请求信息
    private void receive() {
        
        try {
            //1、监听
            Socket client=server.accept();
            //2、获取用户的请求    
            //封装请求信息
            Request req=new Request(client.getInputStream());
        
            
            //对以下响应信息进行封装
            /**
             * 返回响应信息。做出响应。
             */
            //响应头信息
        /**    StringBuilder sb=new StringBuilder();
            sb.append("HTTP/1.1").append(" ").append(200).append(" ").append("登录成功。");
            sb.append("Content-Type:text/html;charst=utf-8").append("\r\n");
            //响应内容
            String str="<html><head><title>响应结果</title><meta charset=\"utf-8\"/></head><body>登录成功!</body></html>";
            sb.append("Content-Length:"+str.getBytes("utf-8").length).append("\r\n");
            sb.append("\r\n");
            sb.append(str);
            
            //通过输出流发送出去
            BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(client.getOutputStream(),"utf-8"));
            bw.write(sb.toString());
            bw.flush();
            bw.close();
        */    
            
            //使用封装的响应方法
            Response rep=new Response(client.getOutputStream());
            Servlet servlet=WebApp.getServlet(req.getUrl());
            int code=200;
            if(servlet==null) {
                code=404;
            }
            //调用servlet中的复地方法
            try {
                servlet.service(req, rep);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            rep.pushToClient(code);
            IOCloseUtil.closeAll(client);
            
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
    }

    public void stop() {
        
    }  
    
}

loginservlet类:

package Servlet;

import Server.Request;
import Server.Response;

public class LoginServlet extends Servlet {

    @Override
    public void doGet(Request req, Response rep) throws Exception {
        //获取请求参数
        String name=req.getParamter("username");
        String pwd=req.getParamter("pwd");
        
        if(this.login(name, pwd)) {
            //调用响应中的构建内容的方法
            rep.println("登录成功");
        }else {
            rep.println("登录失败,账号或密码错误");
        }
        
    }
    
    private boolean login(String name,String pwd) {
        if("bjsxt".equals(name)&&"123".equals(pwd)) {
            return true;                
        }
        return false;
    }

    @Override
    public void doPost(Request req, Response rep) throws Exception {
        // TODO Auto-generated method stub
        
    }

}

servlet类:

package Servlet;

import Server.Request;
import Server.Response;

/**
 *是所用请求的Servlet类的父类
 */
public abstract class Servlet {//处理请求与响应的方法
    public void service(Request req,Response rep) throws Exception {
        this.doGet(req,rep);
        this.doPost(req,rep);
    }
    public abstract void doGet(Request req,Response rep) throws Exception;
    public abstract void doPost(Request req,Response rep) throws Exception;

}


JAVA 全系列/第二阶段:JAVA 基础深化和提高/手写服务器项目(旧) 30339楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/虚拟环境 30340楼

老师这节课的第二个实操,其实也有第二种方法,全部浮动向左好理解些。

<!DOCTYPE html>

<html lang="en">


<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>


    <style>

        /*清空浏览器默认边距*/

        * {

            margin: 0;

            padding: 0;

        }

        .container {

            height: 600px;

            width: 600px;

        }

        .left {

            float: left;

            height: 600px;

            width: 200px;

            background-color: rgb(205, 196, 255);

        }

        .right {

            float: left;

            height: 600px;

            width: 400px;

            background-color: bisque;

        }

        .top {

            height: 300px;

            width: 400px;

            background-color: rgb(28, 162, 196);

        }

        .bottom-left {

            float: left;

            height: 300px;

            width: 200px;

            background-color: rgb(196, 28, 196);

        }

        .bottom-right {

            float: left;

            height: 300px;

            width: 200px;

            background-color: rgb(109, 196, 28);

        }

    </style>

</head>


<body>

    <div class="container">

        <div class="left"></div>

        <div class="right">

            <div class="top"></div>

            <div class="bottom-left"></div>

            <div class="bottom-right"></div>

        </div>

    </div>

</body>


</html>


WEB前端全系列/第一阶段:HTML5+CSS3模块/初识CSS 30341楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 30342楼

老师,我重写了比较的方法,但是排序仍然出现问题,没找到哪里不对,望指正

package Test2001;

import java.util.Arrays;
import java.util.Scanner;

public class Test02 {
    public static void main(String[] args) {
        shangpin[] aa=new shangpin[5];
        aa[0] = new shangpin(1,"百战牌鼠标","BZ_001",99.21,0.9);
        aa[1] = new shangpin(2,"键盘侠玩偶","WO_102",403.00,0.7);
        aa[2] = new shangpin(3,"实战java程序设计","BK_001",89.00,0.8);
        aa[3] = new shangpin(4,"高琪牌西装","GQ_XF_12",700.00,0.5);
        aa[4] = new shangpin(5,"大米牌手机","DM_PH_13",900.00,0.3);
        for (int i = 0; i < 5; i++) {
            System.out.println(aa[i]);
        }
        System.out.println("请输入一个价格");
        Scanner yy=new Scanner(System.in);
        double x=(double)(yy.nextInt());
        for (int i = 0; i < 5; i++) {
            aa[i].zhiding(x);
        }
        Arrays.sort(aa);
        for (int i = 0; i < 5; i++) {
            System.out.println(aa[i]);
        }

    }
}
class shangpin{
    private int id;
    private String name;
    private String xinghao;
    private double jiage;
    private double zhekou;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getXinghao() {
        return xinghao;
    }

    public void setXinghao(String xinghao) {
        this.xinghao = xinghao;
    }

    public double getJiage() {
        return jiage;
    }

    public void setJiage(double jiage) {
        this.jiage = jiage;
    }

    public double getZhekou() {
        return zhekou;
    }

    public void setZhekou(double zhekou) {
        this.zhekou = zhekou;
    }

    public shangpin(int id, String name, String xinghao, double jiage, double zhekou) {
        this.id = id;
        this.name = name;
        this.xinghao = xinghao;
        this.jiage = jiage;
        this.zhekou = zhekou;
    }

    public shangpin() {
    }

    @Override
    public String toString() {
        return "{" +
                 id +"\t"+
                 name + "\t" +
                 xinghao + "\t" +
                 jiage +"\t"
                 + zhekou +
                '}';
    }


    public void zhiding(double a){
        if(this.jiage*this.zhekou>a){
            System.out.println("{" +
                    id +"\t"+
                    name + "\t" +
                    xinghao + "\t" +
                    jiage +"\t"
                    + zhekou +
                    '}');

        }
    }
    public int compareTo(Object o){
        shangpin m2=(shangpin)o;
        if(this.zhekou>m2.zhekou){
            return 1;
        }
        if(this.zhekou<m2.zhekou){
            return -1;
        }
        return 0;
    }
}


JAVA 全系列/第一阶段:AI驱动的JAVA编程/数组和数据存储 30343楼

/**
 * 瀑布流效果:
 *      1.第二行的第一张图片,应该放在每列的高度最矮的图片下面
 * 
 */

window.onload=function(){
    waterFlow()
}

//1.动态设置页面居中

function waterFlow(){
    //获取父级容器
    var parenterContainer =document.getElementById('container');
    //获取所有子元素
    var allChild=document.querySelectorAll('.box');
    //获取屏幕的宽度
    var screenWidth=document.documentElement.clientWidth;
    //获取一个图片容器的宽度
    var childWidth =allChild[0].offsetWidth;
    //计算屏幕水平方向最多能摆放的图片个数
    var rowsNum=Math.floor(screenWidth/childWidth)-1;
    //让页面左右居中
    parenterContainer.style.cssText='width:'+childWidth*rowsNum+'px;margin:0 auto;'

    getMinHeightOfCols(allChild,rowsNum)
}

//2.动态设置图片位置

function getMinHeightOfCols(allChild,rowsNum){
    //存储每列的高度
    var colsHeightArr=[];
    for(var i=0;i<allChild.lenght;i++){
        //判断取出第一行的图片,获取图片对应的高度,放入到数组中
        if(i<rowsNum){
            //获取当前图片的高度
            colsHeightArr[i]=allChild[i].offsetHeight;
        }else{
            //获取列高度最小的值
            var minHeightOfCols=Math.min.apply(null,colsHeightArr)
            console.log(minHeightOfCols);
            //获取最小值对应的下标(位置)
            var minHeightOfIndex=colsHeightArr.indexOf(minHeightOfCols)
            //摆放第二张图片的位置
            allChild[i].style.position="absolute";
            allChild[i].style.top=minHeightOfCols+'px'
            allChild[i].style.left=allChild[minHeightOfIndex].offsetLeft+'px'

            //高度的合并
            colsHeightArr[minHeightOfIndex]=colsHeightArr[minHeightOfIndex]+allChild[i].offsetHeight
        }
    }
    console.log(colsHeightArr);
}

为什么连列表都放不进去啊,代码有什么问题吗

Python 全系列/第七阶段:网页编程基础/DOM模型 30345楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637