会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132884个问题
Python 全系列/第一阶段:Python入门/Python入门(动画版) 35521楼
JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 35522楼

老师您好!请问一下我这个怎么测试出来有null值,幸苦帮忙解答一下,谢谢!

截图:image.png

代码:

package com.bjsxt.server;

import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.jar.Attributes.Name;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class WebDom4j {	//用于解析XML
	private List<Entity> entityList;//用于存储是N多Entity,而每一个Entity都是servlet-name与servlet-class
	private List<Mapping>mappingList;//用于存储是N多Mapping,而每一个Mapping都是servlet-name与N多个url-pattern
	public List<Entity> getEntityList() {
		return entityList;
	}
	public void setEntityList(List<Entity> entityList) {
		this.entityList = entityList;
	}
	public List<Mapping> getMappingList() {
		return mappingList;
	}
	public void setMappingList(List<Mapping> mappingList) {
		this.mappingList = mappingList;
	}
	//构造方法
	public WebDom4j(){
		entityList=new ArrayList<Entity>();
		mappingList=new ArrayList<Mapping>();
	}
	//获取Document对象的方法
	private Document getDocument(){
		try {
			//(1)创建SAXReader对象
			SAXReader reader=new SAXReader();
			//(2)调用read方法
			return reader.read(new File("src/WEB_INFO/web.xml"));
		} catch (DocumentException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return null;
	}
	public void parse(Document doc){
		//(1)获取根元素
		Element root=doc.getRootElement();//web-app
		//(2)获取servlet子元素
		for(Iterator<Element> ite=root.elementIterator("servlet");ite.hasNext();){
			Element subElement=ite.next();	//得到每一个servlet
			//创建一个实体类
			Entity ent=new Entity();//用于存储servlet-name与servlet-class
			for(Iterator<Element> subIte=subElement.elementIterator();subIte.hasNext();){
				Element ele=subIte.next();//可能是servlet-name也可能是servlet-class
				if ("servlet-name".equals(ele.getName())) {
					ent.setName(ele.getText());//给实体类中的name赋值
				}else if("serlvet-class".equals(ele.getName())){
					ent.setClazz(ele.getText());
				}
			}
			//将Entity添加到集合中
			entityList.add(ent);
		}
		//测试
		/*for (Entity entity : entityList) {
			System.out.println(entity.getName()+"\t"+entity.getClazz());
		}*/
		//解析servlet-mapping
		for(Iterator<Element> ite=root.elementIterator("servlet-mapping");ite.hasNext();){
			Element subEle=ite.next();//得到每一个servlet-mapping
			//创建一个mapping类的对象
			Mapping map=new Mapping();
			//解析servlet-mapping下的子元素
			for(Iterator<Element> subIte=subEle.elementIterator();subIte.hasNext();){
				Element ele=subIte.next();//Servlet-name,也有可以是url-pattern
				if("servlet-name".equals(ele.getName())){
				map.setName(ele.getText());
				}else if("url-pattern".equals(ele.getName())){
					//获取集合对象,调用集合对象的添加方法,添加元素
					map.getUrlPattern().add(ele.getText());
				}
			}
			//mapping添加到集合中
			mappingList.add(map);
		}
		//测试
		for (Mapping m : mappingList) {
			System.out.println(m.getName());
			for(String s:m.getUrlPattern()){
				System.out.println(s);
			}
		}
	}
	//用于测试
	public static void main(String[] args) {
		WebDom4j web=new WebDom4j();
		web.parse(web.getDocument());
	}
}


JAVA 全系列/第二阶段:JAVA 基础深化和提高/手写服务器项目(旧) 35523楼
Python 全系列/第二阶段:Python 深入与提高/模块 35525楼
JAVA 全系列/第一阶段:JAVA 快速入门/控制语句、方法、递归算法 35529楼

老师,我这个为什么运行第二行和第三行都对,第一行的格式不对啊?

package com.homework.ljq;

public class homework01 {
    public static void main(String[] args) {

        Emp1 emp0 = new Emp1(1001,"高淇",18,"程序员",30000,5000);
        Emp1 emp1 = new Emp1(1002,"高小二",19,"程序员",35000,2000);
        Emp1 emp2 = new Emp1(1003,"高小三",20,"程序员",25000,3000);

        Emp1[] emp = new Emp1[3];
        emp[0] = emp0;
        emp[1] = emp1;
        emp[2] = emp2;

        for (int i = 0;i<emp.length;i++){
            System.out.println(emp[i]);
        }
    }
}
class Emp1{
    private int id;
    private String name;
    private int age;
    private String job;
    private int salary;
    private int helpSalary;

    //空构造器
    public Emp1(){}

    //构造器
    public Emp1(int id, String name, int age, String job, int salary, int helpSalary) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.job = job;
        this.salary = salary;
        this.helpSalary = helpSalary;
    }

    @Override
    public String toString() {
        return getId()+"\t"+getName()+"\t"+getAge()+"\t"+getJob()+"\t"+getSalary()+"\t"+getHelpSalary()+"\t";
    }

    //构造get和set方法
    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 int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getJob() {
        return job;
    }

    public void setJob(String job) {
        this.job = job;
    }

    public int getSalary() {
        return salary;
    }

    public void setSalary(int salary) {
        this.salary = salary;
    }

    public int getHelpSalary() {
        return helpSalary;
    }

    public void setHelpSalary(int helpSalary) {
        this.helpSalary = helpSalary;
    }
}

批注 2020-07-04 113933.png

JAVA 全系列/第一阶段:JAVA 快速入门/数组和数据存储 35530楼
软件测试 全系列/第二阶段:Windows服务器/搭建Web服务器 35531楼
JAVA 全系列/第十八阶段:亿级高并发电商项目_架构/编码(旧)/电商:基于FastDFS+Nginx+Kinkeditor实现商品新增 35532楼
Python 全系列/第四阶段:函数式编程和核心特性/生成器、迭代器、动态性 35533楼
JAVA 全系列/第九阶段:权限控制与安全认证/Shiro(旧) 35534楼

image.png

一直报404,post和get请求无法返回,

HTML代码

<!DOCTYPE html>
<html lang = "en">
<head>
    <meta charset = "UTF-8">
    <title>08_Ajax的简单封装处理响应.html</title>
</head>
<body>
<h1>08_Ajax的简单封装处理响应.html</h1>
<input type="button" value="测试响应处理" onclick="test1()">
<input type="button" value="测试响应的参数结果处理" onclick="test2()">
<script>
    function ajax(options) {
        var xhr=new XMLHttpRequest()
        var params=''
        // params=options.data
        for(var atr in options.data){
            params=params+atr+'='+options.data[atr]+'&'
        }
        params=params.substr(0,params.length-1)
        //get
        if(options.type==='get'){
            options.url=options.url+'?'+params
        }
        xhr.open(options.type,options.url)
        //post
        if(options.type==='post'){
            xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded')
            xhr.send(params)
        }else{
            xhr.send()
        }

        xhr.onreadystatechange=function () {
            if(xhr.readyState===4 && xhr.status===200){
                if(xhr.getResponseHeader('Content-type').includes('application/json')){
                    options.success(JSON.parse(xhr.responseText))
                }else{
                    options.success(xhr.responseText)
                }
            }else{
                options.error(xhr)
            }
        }
    }

    function test1() {
        ajax({
            type:'get',
            url:'/login',
            data:{'name':'王大禄','pwd':123},
            success:function (resp) {
                console.log(resp)
            },error:function (xhr) {
                console.log(xhr.readyState)
            }
        })
    }
    function test2() {
        ajax({
            type: 'post',
            url: '/state',
            data: {'name': '王大禄', 'pwd': 123},
            success:function (res) {
                console.log(res)
            },error:function () {}
        })
    }
</script>

</body>
</html>


Python代码

# coding=utf-8
from flask import Flask, request, render_template

app = Flask(__name__)


@app.route('/login', methods=['GET', 'POST'])
def login():
    if request.method == 'GET':
        return 'get请求成功'
    elif request.method == 'POST':
        return 'post请求成功'


@app.route('/')
def test():
    return render_template('03_Ajax的post的参数传递.html')


@app.route('/state', methods=['GET','POST'])
def state():
    if request.method == 'GET':
        return render_template('04_Ajax的state的使用.html')
    elif request.method == 'POST':
        # return 'post请求成功'
        # return '{"name":"王大禄","age":20}'
        return '{"name":"王大禄","age":20}', 200, [("Content-type", "application/json")]


@app.route('/async')
def asynca():
    return render_template('05_Ajax的异步与同步使用.html')


@app.route('/fz01')
def fz01():
    return render_template('06_Ajax的简单封装.html')


@app.route('/fz02')
def fz02():
    return render_template('07_Ajax的简单封装的传参.html')


@app.route('/fz03')
def fz03():
    return render_template('08_Ajax的简单封装处理响应.html')


@app.route('/fz04')
def fz04():
    return render_template('09_Ajax的简单封装参数默认值.html')


if __name__ == "__main__":
    app.run(debug=True)


Python 全系列/第七阶段:网页编程基础/Ajax 35535楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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