会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132911个问题

问题: 双向通信的时候, 包没有按照老师一样命名, 一直报错:java.net.SocketException: Connection reset


代码如下

1-客户端:


package com.bzsxt.client;


import java.io.DataInputStream;

import java.io.IOException;

import java.io.ObjectOutputStream;

import java.net.Socket;

import java.net.UnknownHostException;

import java.util.Scanner;


public class TestClient {


public static void main(String[] args) throws UnknownHostException, IOException {

// (1)创建Socket对象,用于连接服务器

Socket client = new Socket("localhost", 10001);

// (2)获取输出流 (对象流)

ObjectOutputStream oos = new ObjectOutputStream(client.getOutputStream());

// (3)创建User对象

// 调用获取用户对象的方法

//User u = getUser();// new User("bjsxt", "bjsxt");

User u = new User("bjsxt", "bjsxt");

// (4)User对象发送到服务器

oos.writeObject(u);

// (5)获取输入流(数据流)

DataInputStream dis = new DataInputStream(client.getInputStream());

System.out.println(dis.readUTF());

// (6)关闭流

if (dis != null) {

dis.close();

}

if (oos != null) {

oos.close();

}

if (client != null) {

client.close();

}

}

// 获取用户对象的方法

public static User getUser() {

Scanner input = new Scanner(System.in);

System.out.println("请输入用户名:");

String userName = input.next();

System.out.println("请输入密码:");

String password = input.next();

// 封装成User对象

return new User(userName, password);

}

}

2-实例类:


package com.bzsxt.client;

import java.io.Serializable;


public class User implements Serializable{


/**

*/

private static final long serialVersionUID = 8868213509492563406L;

private String userName;

private String pwd;

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

public String getPwd() {

return pwd;

}

public void setPwd(String pwd) {

this.pwd = pwd;

}

@Override

public String toString() {

return "User [userName=" + userName + ", pwd=" + pwd + "]";

}

public User(String userName, String pwd) {

super();

this.userName = userName;

this.pwd = pwd;

}

public User() {

super();

}

}

3-服务器端:


package com.bzsxt.server;


import java.io.DataOutputStream;

import java.io.IOException;

import java.io.ObjectInputStream;

import java.net.ServerSocket;

import java.net.Socket;

import com.bzsxt.entity.User;

public class TestServer {


public static void main(String[] args) throws IOException, ClassNotFoundException {

ServerSocket server = new ServerSocket(10001);

System.out.println("服务端开启");

Socket socket = server.accept();

ObjectInputStream oStream = new ObjectInputStream(socket.getInputStream());

User user  = (User) oStream.readObject();

String data = "";

System.out.println(socket.getInetAddress().getHostAddress()+"请求登录:用户名"+user.getUserName()+"\t密码:"+user.getPwd());

System.out.println("----"+user.getUserName());

System.out.println("----"+user.getPwd());

if ("bzsxt".equals(user.getUserName())&&"bzsxt".equals(user.getPwd())){

data = "登录成功";

}else {

data= "登录失败";

}

DataOutputStream dStream = new DataOutputStream(socket.getOutputStream());

dStream.writeUTF(data);

//socket.shutdownOutput();

if (dStream!=null) {

dStream.close();

}if (oStream!=null) {

oStream.close();

}if (socket!=null) {

socket.close();

}

}

}

4-实体类:


package com.bzsxt.entity;

import java.io.Serializable;

public class User implements Serializable{


/**

*/


private static final long serialVersionUID = 8868213509492563406L;


private String userName;


private String pwd;


public String getUserName() {


return userName;


}


public void setUserName(String userName) {


this.userName = userName;


}


public String getPwd() {


return pwd;


}


public void setPwd(String pwd) {


this.pwd = pwd;


}


@Override


public String toString() {


return "User [userName=" + userName + ", pwd=" + pwd + "]";


}


public User(String userName, String pwd) {


super();


this.userName = userName;


this.pwd = pwd;


}


public User() {


super();


}


}


截图结果:



源码:

client.zip

server.zip


JAVA 全系列/第二阶段:JAVA 基础深化和提高/网络编程(旧) 14327楼

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			tr{
				height: 70px;
			}
			td,th{
				width: 120px;
				text-align: center;
			}
		</style>
		<script type="text/javascript">
			function addNode(){
				//获得table表格对象
				var tab=document.getElementById("tab")
				//创建tr节点对象
				var tr=document.createElement("tr");
				//创建td对象
				var td1=document.createElement("td");
				//这里的this表示本身,和python里的self一样
				//这个事件是失去焦点就存储文本
				td1.innerHTML="<input type='text' size='10px' onblur='seaveVal(this)' />"
				var td2=document.createElement("td");
				td2.innerHTML="<input type='text' size='10px' />"
				var td3=document.createElement("td");
				td3.innerHTML="<input type='button' value='添加' />"+" "+"<input type='button' value='删除' onclick="removeNode(this)"  />"
				//添加节点
				tab.appendChild(tr);
				tr.appendChild(td1);
				tr.appendChild(td2);
				tr.appendChild(td3);
			}
			function seaveVal(thi){
				//input按钮框的值是按钮值
				//input的文本框里的值就是输入值,要把值给父级标签td
				//因为这里的this是获得文本标签,先获得父级标签
				var td=thi.parentNode;
				td.innerText=thi.value;
				
			}
			function removeNode(thi){
				//获得父节点tr//input父节点的父节点
				tr=thi.parentNode.parentNode
				tr.remove()
			}
		</script>
	</head>
	<body>
		<table border="1px" id="tab" align="center" style="border: 2px solid beige; ">
			<tr>
				<th>图书名称</th>
				<th>图书价格</th>
				<th>操作</th>
			</tr>
			<tr>
				<td>JAVASE</td>
				<td>19</td>
				<td>
					<input type="button" name="" id="" value="添加" onclick="addNode()" />
					<input type="button" name="" id="" value="删除" />
				</td>
			</tr>
			<tr>
				<td>JAVAEE</td>
				<td>29</td>
				<td>
					<input type="button" name="" id="" value="添加" />
					<input type="button" name="" id="" value="删除" />
				</td>
			</tr>
		</table>
	</body>
</html>

为啥删除操作执行不了,把那个onclick去掉就可以用添加

Python 全系列/第七阶段:网页编程基础/JavaScript 14329楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器 14330楼

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script>
			/***验证码的生成****/
			function YZM(){
				var ran=Math.floor(Math.random()*9000+1000);
				//获得span对象
				var span=document.getElementById("yzm_span");
				//把验证码给span
				span.innerHTML=ran
			}
			//校验用户名的操作
			function checkName(){
				//获得用户名的值
				var uname=document.getElementById("uname").value;
				//获得span对象
				var span=document.getElementById("uname_span");
				
				//汉字的正则表达式
				var reg=/^[\u4e00-\u9fa5]{2,5}$/;
				
				if(uname==null||uname==""){
					span.innerHTML="×用户名不能为空"
					span.style.color="red"
				}
				//正则表达式的校验   re.test(value)
				else if(reg.test(uname)){
					span.innerHTML="√用户名合法"
					span.style.color="green"
				}
				else{
					span.innerHTML="×用户名不合法"
					span.style.color="red"
				}
			}
			/**对数据格式进行一定的规范限制(www.jb51.net)正则表达式的使用**/
			//对复杂的正则表达式,只用看懂就行,直接去搜
			/**
			 * ^匹配字符串开头
			 * [0-9] [a-z]:数字和字母范围
			 * {2,4}:段域 至少是2位数,最多4位数
			 * {2,}至少两位
			 * $匹配结束
			 * \d [0-9]
			 * \w [a-z A-Z 0-9]
			 * 
			 */
		</script>
	</head>
	<body onload="YZM()">
		<center>
		<h3>注册界面</h3>
		<hr />
		<form action="" method="get">
			<table>
				<tr height="35px">
					<td width="150ox">用户名</td>
					<td width="400px">
						<input type="text" name="uname" id="uname" value="" alt="用户名" onblur="checkName()" />
						<span id="uname_span">*用户名必须是三到五位的汉字</span><br />
					</td>
				</tr>
				<tr height="35px">
					<td>密码:</td>
					<td>
						<input type="password" name="pwd" id="pwd" value="" alt="密码"  />
					</td>
				</tr>
				<tr height="35px">
					<td>手机号:</td>
					<td>
						<input type="text" name="phone" id="phone" value="" alt="手机号"  />
					</td>
				</tr>
				<tr height="35px">
					<td>邮箱:</td>
					<td>
						<input type="text"  />
					</td>
				</tr>
				<tr height="35px">
					<td>籍贯:</td>
					<td>
						<select name="address" id="sel">
							<option value="0">--请选择--</option>
							<option value="1">湖南</option>
							<option value="2">山东</option>
							<option value="30">广东</opntion>
						</select>
					</td>
				</tr>
				<tr height="35px">
					<td>验证码</td>
					<td>
						<input type="number" name="" id="yzm" value="" />
						<span id="yzm_span"></span>
					</td>
				</tr>
				<tr height="35px">
					<td>个人介绍:</td>
					<td>
						<textarea name="intro" rows="8" cols="30"></textarea>
					</td>
				</tr>
				<tr>
					<td></td>
					<td></td>
				</tr>
			</table>		
		</center>
	</body>
</html>
	

这里的

<span id="uname_span">*用户名必须是三到五位的汉字</span><br />

会被

span.innerHTML="√用户名合法"

取缔原来的文本值是为啥

Python 全系列/第七阶段:网页编程基础/JavaScript 14332楼
Python 全系列/第十四阶段:Python 爬虫开发/scrapy框架使用 14333楼
Python 全系列/第十四阶段:Python 爬虫开发/爬虫基础 14335楼

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title></title>
      <script>
         
         function  demo1(){
            
            //获得id名称是div1的对象
            
            var div =document.getElementById("div1");
            
            //获得css样式  只是支持行内样式的css
            
            var  wi=div.style.width;
            
            
            var  hi=div.style.height;
            
            
//          alert(wi+"----"+hi);
            
            
            //操作元素的css样式    
            
            div.style.width="300px";
            
            
            div.style.height="300px";
            
            
            div.style.backgroundColor="red";
            
            div.style.border="3px solid green";
            //通过增加class类来增加对应的css样式  
            //div.className="div2";
            
         }
         
         
      </script>
   
      
      <style>
         
         .div2{
            
            
            border: 3px solid  green;
            
            
            
         }
         
         
      </style>
      
      
   </head>
   <body >
      
      <div id="div1"  style="width: 200px; height: 200px; background-color: palegreen;"></div>
      
      <hr />
      
      <input type="button" name="" id="" value="css样式的操作" onclick="demo1()" />
   </body>
</html>

老师这里我没用增加类的方式增加新的样式,用这个也能增加样式,但是老师讲课好像没说这个,是因为浏览器强大能识别还是这个操作是可以增加样式的

div.style.border="3px solid green";


JAVA 全系列/第四阶段:网页编程和设计/Javascript 语言(旧) 14336楼
JAVA 全系列/第五阶段:JavaWeb开发/Web实战案例 14337楼
JAVA 全系列/预科阶段:职业规划/学习方法/程序员的基本素养和职业规划 14338楼
WEB前端全系列/第十九阶段:Vue2知识体系(旧)/Vue基础知识 14339楼
Python 全系列/第二阶段:Python 深入与提高/游戏开发-坦克大战 14340楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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