Struts2框架实现图书管理

**

Struts2框架实现图书管理:(图书的增删改查)

**
1.首先我们得确保struts框架搭建完毕
在lib下放入我们所需要的jar包
在这里插入图片描述

2.先新建一个数据库来存储数据:
在MyDB库下创建一个book表:
在这里插入图片描述
注意:id设置成主键自增
3.创建一个web项目然后把包结构创建成mvc结构:
在这里插入图片描述
注意:user文件夹来放置用户登陆页面 book文件夹来存图书管理页面
登陆页面:login.jsp(在user下)

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>登录页面</title>
  </head>
  
  <body>
    <form action="<%=basePath%>/user/login" method="post">
          用户名:<input type="text" name="name"/><br>
          密码:<input type="text" name="pwd"/><br>
    <input type="submit" value="提交"/>
    </form>
  </body>
</html>

图书管理bookList.jsp(在book下):

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"  %>
<%@ taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
   <style type="text/css">
    body{
    	margin-left: 200pt;
    }
    table,table tr th, table tr td 
    	{
    		border: 1px solid grey
   		 }
    </style>
    <base href="<%=basePath%>">
    
    <title>图书管理</title>
  </head>
  
  <body>
  <a href='<%=basePath %>book/toAddBook'>新增图书</a>
     <table>
       <thead>
         <tr>
           <th>编号</th>
           <th>书名</th>
           <th>作者</th>
           <th>出版社</th>
           <th>ISBN</th>
           <th>操作</th>
         </tr>
       </thead>
       <tbody>
       <s:iterator value="#request.books" status="book">
           <tr>
             <td><s:property value="id" /><br/></td>
             <td><s:property value="bookName" /><br/></td>
             <td><s:property value="bookAuthor" /><br/></td>
             <td><s:property value="bookPublish" /><br/></td>
             <td><s:property value="bookIsbn" /><br/></td>
             <td><a href="<%=basePath %>book/selectBookId?book.id=<s:property value="id"/>">更新</a> <a href="<%=basePath %>book/delBook?book.id=<s:property value="id"/>">删除</a></td>
           </tr>
           </s:iterator>
       </tbody>
    </table>
  </body>
</html>

新增图书页面addBook.jsp(在book下):

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>新增图书</title>

  </head>
  
  <body>
        <form  action="book/addBook" method="post">
		书名:<input type="text" name="book.bookName" /><br /> 
		作者:<input type="text" name="book.bookAuthor" /><br /> 
		ISBN:<input type="text" name="book.bookIsbn" /><br /> 
		出版商:<input type="text" name="book.bookPublish" /><br /> 
		<input type="submit" value="提交" />
	    </form>
  </body>
</html>

更新图书manage.jsp页面(在book下):

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"  %>
<%@ taglib prefix="s" uri="/struts-tags" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>更新页面</title>
  </head>
  
  <body>
    更新内容:
    <form action="book/updateBook" method="post">
	    <table>
		    <thead>
		    		<tr>
		    			<th>编号</th>
		    			<th>图书名称</th>
		    			<th>作者</th>
		    			<th>出版社</th>
		    			<th>ISBN</th>   			
		    		</tr>
		    </thead>
		    <s:iterator value="#request.booksId" status="booksId">
		   		<tr>
			  		<td><input type="text" value=" <s:property value="id"/>" name="book.id"/></td>
			  		<td><input type="text" value=" <s:property value="bookName"/>" name="book.bookName"/></td>
			  		<td><input type="text" value=" <s:property value="bookAuthor"/>" name="book.bookAuthor"/></td>
			  		<td><input type="text" value=" <s:property value="bookIsbn"/>" name="book.bookIsbn"/></td>
			  		<td><input type="text" value=" <s:property value="bookPublish"/>" name="book.bookPublish"/></td>
		  		</tr>		  	
		  	</s:iterator> 
	    </table>
	    <input type="submit" value="提交"/>
    </form>
  </body>
</html>

4.接着来写action包的内容来实现登陆功能:
LoginAction.java(注意是class文件)

package com.cq.action;

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionSupport;

public class LoginAction extends ActionSupport {
    private String name;
    private String pwd;
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getPwd() {
		return pwd;
	}
	public void setPwd(String pwd) {
		this.pwd = pwd;
	}
	public String login(){
		if(name!=null && !"".equals(name) &&pwd!=null && !"".equals(pwd) ){
    		if("admin".equals(name) && "123".equals(pwd)){
    		   Map<String,Object>session = ActionContext.getContext().getSession();
    		   session.put("user",name);
    			return "success";
    		}else{
    			return "fail";
    		}
    	}else{
    		return "fail";
    	}
    }
}

dao包内容:
BookDao.java

package com.cq.dao;

import java.util.List;

import com.cq.bean.Book;

public interface BookDao {
	/**
	 * 查询所有图书
	 * @return
	 */
	public List<Book> selectBooks();
	/**
	 * 增加图书
	 * @param book
	 * @return
	 */
	public boolean addBook(Book book);

	/**
	 * 根据图书ID删除图书
	 * @param bookId
	 * @return
	 */
	public boolean deleteBook(int bookId);
	
	/**
	 * 根据图书ID查询图书
	 * @param bookId
	 * @return
	 */
	public Book selectBookId(int bookId);
	
	/**
	 * 更新图书信息
	 * @param book
	 * @return
	 */
	public boolean updateBook(Book book);

}

dao.impl包内容:(注意要和BookDao实现接口)
BookDaoImpl.java

package com.cq.dao.impl;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import com.cq.bean.Book;
import com.cq.dao.BookDao;
import com.cq.util.DButil;

public class BookDaoImpl implements BookDao {

	public List<Book> selectBooks() {
		// TODO 交接数据库
		Connection conn = DButil.getConn();
		
		String sql = "select * from book";
		
		PreparedStatement ps = null;
		ResultSet rs = null;
		
		List<Book> books = new ArrayList<Book>();
		
		try{
			ps = conn.prepareStatement(sql);
			rs = ps.executeQuery();
			while(rs.next()){
				Book book = new Book();
				book.setId(rs.getInt(1));
				book.setBookName(rs.getString(2));
				book.setBookAuthor(rs.getString(3));
				book.setBookPublish(rs.getString(4));
				book.setBookIsbn(rs.getString(5));
				books.add(book);
			}
		}catch(SQLException e){
			e.printStackTrace();
		}finally{
			DButil.closeConn(conn, ps, rs);
		}
		return books;
	}

	public boolean addBook(Book book) {
		Connection conn = DButil.getConn();
		String sql = "insert into book (book_name,book_author,book_isbn,book_publish) values (?,?,?,?)";
		PreparedStatement ps = null;
		int count = 0;
		try {
			ps = conn.prepareStatement(sql);
			ps.setString(1, book.getBookName());
			ps.setString(2, book.getBookAuthor());
			ps.setString(3, book.getBookIsbn());
			ps.setString(4, book.getBookPublish());
			count = ps.executeUpdate();

		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			DButil.closeConn(conn, ps, null);
		}

		if (count > 0)
			return true;
		else
			return false;
	}

	public boolean deleteBook(int bookId) {
		Connection conn = DButil.getConn();
		String sql = "delete from book where id = ?";
		PreparedStatement ps = null;
		int count = 0;
		try {
			ps = conn.prepareStatement(sql);
			
			ps.setInt(1, bookId);
			count = ps.executeUpdate();

		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			DButil.closeConn(conn, ps, null);
		}

		if (count > 0)
			return true;
		else
			return false;
	}

	public Book selectBookId(int bookId) {
		Connection conn = DButil.getConn();
		String sql = "select * from book where id = ?";
		PreparedStatement ps = null;
		ResultSet rs = null;
		Book book = new Book();
		
		try {
			ps = conn.prepareStatement(sql);
			ps.setInt(1, bookId);
			rs = ps.executeQuery();
			if(rs.next()){
				
				book.setId(rs.getInt(1));
				book.setBookName(rs.getString(2));
				book.setBookAuthor(rs.getString(3));
				book.setBookIsbn(rs.getString(4));
				book.setBookPublish(rs.getString(5));
			
			}

		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			DButil.closeConn(conn, ps, null);
		}
		return book;
	}

	public boolean updateBook(Book book) {
		Connection conn = DButil.getConn();
		String sql = "update  book  set book_name =  ?,book_author = ?,book_isbn = ?,book_publish = ? where id =?" ;
		PreparedStatement ps = null;
		int count = 0;
		try {
			ps = conn.prepareStatement(sql);
			ps.setString(1, book.getBookName());
			ps.setString(2, book.getBookAuthor());
			ps.setString(3, book.getBookIsbn());
			ps.setString(4, book.getBookPublish());
			ps.setInt(5, book.getId());
			count = ps.executeUpdate();

		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			DButil.closeConn(conn, ps, null);
		}
		if (count > 0)
			return true;
		else
			return false;
	}

}

service包内容:
BookService.java

package com.cq.service;

import java.util.List;

import com.cq.bean.Book;

public interface BookService{
	/**
	 * 查询所有图书
	 * @return
	 */
	public List<Book> selectBooks();
	/**
	 * 增加图书
	 * @param book
	 * @return
	 */
	public boolean addBook(Book book);

	/**
	 * 根据图书ID删除图书
	 * @param bookId
	 * @return
	 */
	public boolean deleteBook(int bookId);
	
	/**
	 * 根据图书ID查询图书
	 * @param bookId
	 * @return
	 */
	public Book selectBookId(int bookId);
	
	/**
	 * 更新图书信息
	 * @param book
	 * @return
	 */
	public boolean updateBook(Book book);

}

service.impl包内容:
BookServiceImpl.java

package com.cq.service.impl;

import java.util.List;

import com.cq.bean.Book;
import com.cq.dao.BookDao;
import com.cq.dao.impl.BookDaoImpl;
import com.cq.service.BookService;

public class BookServiceImpl implements BookService {

	/**
	 * 查询所有图书
	 * @return
	 */
	public List<Book> selectBooks() {
		// TODO 从数据库获取内容进行数据组织
		BookDao bookDao = new BookDaoImpl();
		List<Book> books = bookDao.selectBooks();
		return books;
	}

	/**
	 * 增加图书
	 * @param book
	 * @return
	 */
	public boolean addBook(Book book) {
		BookDao bookDao = new BookDaoImpl();
		return  bookDao.addBook(book);
		
		
	}

	/**
	 * 根据图书ID删除图书
	 * @param bookId
	 * @return
	 */
	public boolean deleteBook(int bookId) {
		BookDao bookDao = new BookDaoImpl();
		return  bookDao.deleteBook(bookId);
		
		
	}
	
	/**
	 * 根据图书ID查询图书
	 * @param bookId
	 * @return
	 */
	public Book selectBookId(int bookId) {
		BookDao bookDao = new BookDaoImpl();
		Book book =  bookDao.selectBookId(bookId);
		return book;

	}


	/**
	 * 更新图书信息
	 * @param book
	 * @return
	 */

	public boolean updateBook(Book book) {
		BookDao bookDao = new BookDaoImpl();
		return  bookDao.updateBook(book);
	}

}

(service包内容和dao包内容差不多,是因为service把dao里边的内容又进行过滤)
bean包内容:
Book.java

package com.cq.bean;

public class Book {
   private int id;
   private String bookName;
   private String bookAuthor;
   private String bookPublish;
   private String bookIsbn;
   public int getId() {
	return id;
   }
   public void setId(int id) {
	this.id = id;
   }
   public String getBookName() {
	return bookName;
   }
   public void setBookName(String bookName) {
	this.bookName = bookName;
   }
	public String getBookAuthor() {
	return bookAuthor;
	}
	public void setBookAuthor(String bookAuthor) {
	this.bookAuthor = bookAuthor;
	}
	public String getBookPublish() {
	return bookPublish;
	}
	public void setBookPublish(String bookPublish) {
	this.bookPublish = bookPublish;
	}
	public String getBookIsbn() {
	return bookIsbn;
	}
	public void setBookIsbn(String bookIsbn) {
	this.bookIsbn = bookIsbn;
	}
   
}

interceptor包内容:(此包是实现拦截器功能)
UserInterceptor.java

package com.cq.interceptor;

import org.apache.logging.log4j.util.Strings;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class UserInterceptor extends AbstractInterceptor  {
	@Override
	public String intercept(ActionInvocation invocation) throws Exception {
		String user=(String) ActionContext.getContext().getSession().get("user");
		if(user==null || "".equals(user)){
			return "fail";
		}
		return invocation.invoke();
	}
}

util包内容:(此包是实现数据库连接功能)
DButil.java

package com.cq.util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class DButil {
	public static Connection getConn() {

		String url = "jdbc:sqlserver://localhost:1433;databaseName=MyDB";
		String user = "sa";
		String pwd = "147";
		Connection conn = null;

		try {
			Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
			conn = DriverManager.getConnection(url, user, pwd);
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return conn;
	}

	public static void closeConn(Connection conn, PreparedStatement ps,
			ResultSet rs) {

		try {
			if (conn != null) {
				conn.close();
			}
		} catch (SQLException e) {

			e.printStackTrace();
		}

		try {
			if (ps != null) {
				ps.close();
			}
		} catch (SQLException e) {

			e.printStackTrace();
		}

		try {
			if (rs != null) {
				rs.close();
			}
		} catch (SQLException e) {

			e.printStackTrace();
		}
	}
}

5.接下来在action包实现图书管理功能:
BookAction.java

package com.cq.action;

import java.util.List;

import javax.servlet.http.HttpServletRequest;

import org.apache.struts2.ServletActionContext;

import com.cq.bean.Book;
import com.cq.service.BookService;
import com.cq.service.impl.BookServiceImpl;
import com.opensymphony.xwork2.ActionSupport;

public class BookAction extends ActionSupport {
	private Book book;
	public Book getBook() {
		return book;
	}

	public void setBook(Book book) {
		this.book = book;
	}
	/**
	 * 查询图书
	 * @return
	 */
	public String bookList(){
		//从数据库获取数据 进行数据准备 然后将数据传至bookList.jsp
		BookService bookService = new BookServiceImpl();
		List<Book> books = bookService.selectBooks();
		
		HttpServletRequest request = ServletActionContext.getRequest();
		request.setAttribute("books", books);
		return "success";
	}
	
	/**
	 * 准备新增图书
	 * @return
	 */
	public String toAddBook() {
		return "success";
	}
	
	/**
	 * 新增图书
	 * @return
	 */
	public String addBook() {
		BookService bookService = new BookServiceImpl();
		bookService.addBook(book);
		return "success";
	}
	
	/**
	 * 删除图书
	 * @return
	 */
	public String delBook(){
		BookService bookService = new BookServiceImpl();
		bookService.deleteBook(book.getId());
		return "success";
	}
	
	/**
	 * 根据id查询图书  并跳转到更新图书页面
	 * @return
	 */
	public String selectBookId(){
		BookService bookService = new BookServiceImpl();
		Book booksId = bookService.selectBookId(book.getId());
		HttpServletRequest request = ServletActionContext.getRequest();
		request.setAttribute("booksId", booksId);
		return "success";
	}
	/**
	 * 更新图书
	 * @return
	 */
	public String updateBook(){
		BookService bookService = new BookServiceImpl();
		bookService.updateBook(book);
		return "success";
		
	}
}

struts.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
    <package name="user" namespace="/user" extends="struts-default">
        <action name="login" class="com.cq.action.LoginAction" method="login">
           <result name="success" type="chain">
           	    <param name="namespace">/book</param>
	            <param name="actionName">BookList</param>
	            <param name="method">bookList</param>
            </result>
			<result name="fail">/user/login.jsp</result>
        </action>
    </package>
    <package name="book" namespace="/book" extends="struts-default">
     <!-- 这段代码是配置拦截器功能 -->
		<interceptors>
			<interceptor name="userInterceptor" class="com.cq.interceptor.UserInterceptor"></interceptor>
			<interceptor-stack name="selfStack">
				<interceptor-ref name="userInterceptor"></interceptor-ref>
				<interceptor-ref name="defaultStack"></interceptor-ref>
			</interceptor-stack>
		</interceptors>
		<default-interceptor-ref name="selfStack"></default-interceptor-ref>
		<global-results>
			<result name="fail">/user/login.jsp</result>
		</global-results>
		 <!-- <global-results>标签来定义全局的-->
		<action name="BookList" class="com.cq.action.BookAction"
			method="bookList">
			<result name="success">/book/bookList.jsp</result>
		</action>
		<action name="toAddBook" class="com.cq.action.BookAction"
			method="toAddBook">
			<result name="success">/book/addBook.jsp</result>
		</action>
		<action name="addBook" class="com.cq.action.BookAction"
			method="addBook">
			<result name="success" type="chain">BookList</result>
		</action>
		<action name="selectBookId" class="com.cq.action.BookAction"
			method="selectBookId">
			<result name="success">/book/manage.jsp</result>
		</action>
		<action name="updateBook" class="com.cq.action.BookAction"
			method="updateBook">
			<result name="success" type="chain">BookList</result>
		</action>
		<action name="delBook" class="com.cq.action.BookAction"
			method="delBook">
			<result name="success" type="chain">BookList</result>
		</action>
	</package>
</struts>

web.xml文件:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

效果图:
在这里插入图片描述
就这样图书管理系统就完成了!

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一.功能简介 1. 实现一个图书管理系统。图书信息存放到一个数据库中。图书包含信息:图书号、图书名、作者、价格、备注字段。 2. 系统实现如下的基本管理功能: (1)用户分为两类:系统管理员,一般用户。 (2)提供用户注册和用户登录验证功能;其中登录用户的信息有:登录用户名,登录密码等。 (3)管理员可以实现对注册用户的管理(删除),并实现对图书的创建、查询、修改和删除等有关的操作。 (4)一般用户,只能查询图书,并进行借书、还书操作,每个用户最多借阅8本,即当目前借书已经是8本,则不能再借书了,只有还书后,才可以再借阅。 二.涉及技术 Struts2框架、MySQL数据库、C3P0数据池、Jsp、HTML、CSS、JavaScript等技术。 三.设计思路 1. 基于Struts2框架进行编程设计,连接MySQL数据库实现数据的增删查改,应用Jsp、HTML、CSS、JavaScript对访问页面进行编写和美化。 2. 分别创建book表和user表,用以存放图书信息和用户数据。其中user表中,设有flag以区分管理员和普通用户。 3. 分别创建Book类和User类,与数据表相对应。每本书和每个用户都有唯一的id与之对应。 4. 创建C3P0属性文件和数据库连接工具类。 5. 设计数据库操作类:UserDao类和BookDao类。UserDao用于实现所有对user表的操作,BookDao用于实现所有对book表的操作。 6. 创建分别对应UserDao类和BookDao类的Action:UserAction和BookAction。采用基于注解的方式进行Action配置。 7. 用户账号分为管理员账号和普通用户账号,注册时加以区分,登录时即可自动判断进入对应的操作主页面。 8. 管理员可实现对用户的查询显示,模糊查询,删除,批量删除,全选和取消全选等功能;可实现对图书的查询显示,模糊查询,添加,删除,批量删除,全选和取消全选等功能。 9. 普通用户可实现借书和还书功能,借书功能通过对book表的查询,将未借出的图书按照id顺序排列显示,点击表格后方的“借阅”按钮,进行确认借阅,将book表中本书的borrowperson列的值改为本用户账号。对于借阅成功的图书可以在“当前借阅”中进行查看。还书功能通过在“当前借阅”中点击“还书”按钮,进行确认还书,将book表中本书的borrowperson列的值改为“空”,本书信息将可以在“借书”界面查看。 四.存在的问题 1. 原本希望能为每一个用户创建一个对应的以其账号命名的数据表,用以存放用户所借图书信息,但创建表的SQL语句无法在java代码中执行,所以只好在book表中添加一列borrowperson,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“where borrowperson=‘account’”为条件对book表进行查询即可。但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。 2. 模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询,查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。这种方法虽然实现了查询,但效率太低,代码过于繁重。 五.改进预想 这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。 1. 希望实现登录时验证码验证登录; 2. 希望实现查询时,查询结果分页浏览; 3. 进一步优化Action之间的传值方法; 4. 页面进一步优化、美化; 5. 实现用户借书还书时间记录,和借阅时长限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值