2022.8.16 作业

该代码示例展示了如何使用select函数在TCP客户端中实现数据的接收和发送。通过创建读集合,监控标准输入和套接字文件描述符,实现了与服务器的交互。当有输入时,数据被发送到服务器;当从服务器接收到数据时,将其打印到控制台。

1、用select实现TCP客户端的收发功能

#include <stdio.h>	
#include <sys/select.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>

#define PORT 8888
#define IP "192.168.31.200"

#define ERR_MSG(msg) do{\
	fprintf(stderr,"__%s__ __%d__\n",__func__,__LINE__);\
	perror(msg);\
}while(0)

int main(int argc, const char *argv[])
{
	int cfd=socket(AF_INET,SOCK_STREAM,0);
	if(cfd<0){
		ERR_MSG("socket");
		return -1;
	}
	
	struct sockaddr_in sin;
	sin.sin_family=AF_INET;
	sin.sin_port=htons(PORT);
	sin.sin_addr.s_addr=inet_addr(IP);

	if(connect(cfd,(struct sockaddr *)&sin,sizeof(sin))<0){
		ERR_MSG("connect");
		return -1;
	}

	//创建读集合
	fd_set readfds,tempfds;

	//将读集合清空
	FD_ZERO(&readfds);
	FD_ZERO(&tempfds);
	
	//将文件描述符添加进读集合
	FD_SET(0,&readfds);
	FD_SET(cfd,&readfds);
	
	int maxfd=cfd;
	int res;
	int select_res;
	char buf[128]={0};
	while(1){
		
		tempfds=readfds;
		
		//检测读集合
		select_res=select(maxfd+1,&tempfds,NULL,NULL,NULL);
		if(select_res<0){
			perror("select");
			return -1;
		}else if(0==select_res){
			fprintf(stderr,"select time out\n");
			return -1;
		}
		
		if(FD_ISSET(0,&tempfds)){
			bzero(buf,sizeof(buf));
			fgets(buf,sizeof(buf),stdin);
			buf[strlen(buf)-1]=0;

			if(send(cfd,buf,sizeof(buf),0)<0){
				ERR_MSG("send");
			}
		}

		if(FD_ISSET(cfd,&tempfds)){
			bzero(buf,sizeof(buf));
			res=recv(cfd,buf,sizeof(buf),0);
			if(res<0){
				ERR_MSG("recv");
				return -1;
			}else if(0==res){
				fprintf(stderr,"与服务器断开连接\n");
				return -1;
			}else{
				printf("服务器:%s\n",buf);
			}
		}
	}

	return 0;
}

![](https://cdn.jsdelivr.net/gh/dzg123456/CDN@main/images/20251125143855.png) ### 题目重述 实验题: 1. 创建一个 JSP 页面,包含表单(`form`),支持输入文本、单选按钮、复选框、图片上传,并有提交功能。 2. 提交后跳转到一个 Servlet,显示用户输入的文本、单选结果、复选框结果及上传的图片。 要求:将代码和运行效果图截图作为附件提交。 --- ### 详解(基于 IntelliJ IDEA 2022.1.3 的完整操作步骤) #### ✅ 第一步:创建 Maven Web 项目 1. 打开 **IntelliJ IDEA 2022.1.3**。 2. 选择 `New Project` → `Maven Archetype`。 3. 在 archetype 中选择:`maven-archetype-webapp`。 4. 输入项目信息: - GroupId:如 `com.example` - ArtifactId:如 `jsp-servlet-demo` - Version:1.0-SNAPSHOT 5. 点击 `Finish` 完成创建。 > 若未自动识别为 Web 模块,在 `Project Structure` → `Modules` 中勾选 “Web” 支持并配置 `web.xml` 路径。 --- #### ✅ 第二步:添加必要依赖(`pom.xml`) 打开 `pom.xml`,添加以下依赖以支持 JSP、Servlet 和文件上传: ```xml <dependencies> <!-- Servlet API --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> </dependency> <!-- JSP API --> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> <scope>provided</scope> </dependency> <!-- JSTL 可选(用于增强 JSP 功能) --> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> </dependencies> <!-- 构建插件 --> <build> <finalName>jsp-servlet-demo</finalName> <plugins> <plugin> <groupId>org.apache.tomcat.maven</groupId> <artifactId>tomcat7-maven-plugin</artifactId> <version>2.2</version> <configuration> <port>8080</port> <path>/</path> </configuration> </plugin> </plugins> </build> ``` --- #### ✅ 第三步:创建 JSP 页面(`index.jsp`) 路径:`src/main/webapp/index.jsp` ```jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head><title>用户表单</title></head> <body> <h2>用户信息填写</h2> <form action="DisplayServlet" method="post" enctype="multipart/form-data"> 姓名: <input type="text" name="name" required><br><br> 性别: <input type="radio" name="gender" value="男" checked> 男 <input type="radio" name="gender" value="女"> 女<br><br> 兴趣爱好: <input type="checkbox" name="hobby" value="阅读"> 阅读 <input type="checkbox" name="hobby" value="运动"> 运动 <input type="checkbox" name="hobby" value="音乐"> 音乐<br><br> 头像上传: <input type="file" name="avatar" accept="image/*"><br><br> <input type="submit" value="提交"> </form> </body> </html> ``` --- #### ✅ 第四步:创建 Servlet(`DisplayServlet.java`) 路径:`src/main/java/com/example/DisplayServlet.java` ```java package com.example; import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*; import java.io.IOException; import java.io.PrintWriter; @WebServlet("/DisplayServlet") @MultipartConfig( maxFileSize = 10485760 // 10MB ) public class DisplayServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("UTF-8"); response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); String name = request.getParameter("name"); String gender = request.getParameter("gender"); String[] hobbies = request.getParameterValues("hobby"); Part filePart = request.getPart("avatar"); String fileName = filePart.getSubmittedFileName(); // 返回 HTML 页面 out.println("<!DOCTYPE html>"); out.println("<html><head><title>结果页</title></head><body>"); out.println("<h2>您提交的信息如下:</h2>"); out.println("姓名:" + name + "<br>"); out.println("性别:" + gender + "<br>"); out.println("兴趣爱好:"); if (hobbies != null) { for (String h : hobbies) { out.print(h + " "); } } else { out.print("无"); } out.println("<br>"); if (fileName != null && !fileName.isEmpty()) { // 保存文件(示例路径) String uploadPath = getServletContext().getRealPath("/") + "uploads/"; java.nio.file.Path path = java.nio.file.Paths.get(uploadPath + fileName); filePart.write(path.toString()); out.println("头像:<img src='uploads/" + fileName + "' width='100'><br>"); } out.println("<a href='index.jsp'>返回修改</a>"); out.println("</body></html>"); } } ``` > ⚠️ 注意:首次编译可能报错“无法找到 Servlet 类”,请确认 SDK 已设置为 Java 8 或 11,并在模块中引入 `Tomcat` 库或使用 `provided` 依赖。 --- #### ✅ 第五步:配置 web.xml(可选) 路径:`src/main/webapp/WEB-INF/web.xml` ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <display-name>JSP Servlet Demo</display-name> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app> ``` --- #### ✅ 第六步:运行项目 1. 确保已安装 Tomcat 插件或本地配置了 Tomcat Server。 2. 推荐使用内置 Maven 插件运行: - 打开 Maven 工具栏 → `Plugins` → `tomcat7:run` - 或在 Terminal 执行: ```bash mvn tomcat7:run ``` 3. 浏览器访问:`http://localhost:8080` --- #### ✅ 第七步:测试与截图 1. 填写表单,选择一张图片,点击“提交”。 2. 查看跳转后的页面是否正确显示所有信息(含图片)。 3. 截图两张: - 第一张:`index.jsp` 表单界面 - 第二张:`DisplayServlet` 显示结果页(含图片) 4. 将代码文件与截图打包提交作业附件。 --- ### 知识点(列出该代码中遇到的知识点) 1. **JSP 与 Servlet 数据交互** JSP 负责前端展示,通过 form 提交数据至 Servlet 处理业务逻辑。 2. **文件上传处理(`@MultipartConfig` 与 `Part`)** 必须设置 `enctype="multipart/form-data"`,使用 `getPart()` 获取上传文件。 3. **HTTP 请求参数获取方法** `getParameter()` 获取单值(如文本、单选),`getParameterValues()` 获取多选值。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值