基于javaweb+mysql的springboot物流快递在线寄查快递系统(java+springboot+freemarker+mysql)

基于javaweb+mysql的springboot物流快递在线寄查快递系统(java+springboot+freemarker+mysql)

运行环境

Java≥8、MySQL≥5.7

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的SpringBoot物流快递在线寄查快递系统(java+springboot+freemarker+mysql)

超级管理员:系统管理、用户管理、网点管理、运输点管理、快递员管理、网点申请管理(审核)、报价管理(时效报价)等。

普通用户:注册登录、个人信息管理(个人资料、密码修改等)、地址管理、实名认证、在线寄件(单件寄件、批量导入寄件)、订单查询(物流信息查询)、在线申请网点、投诉建议等。

网点管理员:揽收负责区域的快递,进行快递快递运输,确认到达快递,快递到达后指派网点下快递员进行派送。

运输点管理员:负责运输至该运输点的快递再次运输。

运行环境:windows/Linux均可、jdk1.8、mysql5.7、idea/eclipse均可。


/**
 * @info : 前台网点申请网点申请控制层
 */

@RequestMapping("/admin/branchApplyFor")
@Controller
public class BranchApplyForController {

    @Autowired
    private BranchApplyForService branchApplyForService;
    @Autowired
    private UserService userService;
    @Autowired
    private RoleService roleService;

    /**
     * 网点申请列表页面
     * @param model
     * @param branchApplyFor
     * @param pageBean
     * @return
     */
    @RequestMapping(value="/list")
    public String list(Model model, BranchApplyFor branchApplyFor, PageBean<BranchApplyFor> pageBean){
        model.addAttribute("title", "网点申请列表");
        model.addAttribute("branchName", branchApplyFor.getBranchName());
        model.addAttribute("pageBean", branchApplyForService.findList(pageBean,branchApplyFor.getBranchName(), null));
        return "admin/branch_apply_for/list";
     * 删除运输点
     * @param id
     * @return
     */
    @RequestMapping(value="/delete",method= RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> delete(@RequestParam(name="id")Long id){
        try {
            userService.delete(id);
        } catch (Exception e) {
            return Result.error(CodeMsg.TRANSPORT_USE_DELETE_ERROR);
        }
        operaterLogService.add("删除运输点,运输点ID:" + id);
        return Result.success(true);
    }
    

}

/**
 * 后台角色管理控制器
        }
        if (byMobile.getStatus() == 0){
            return Result.error(CodeMsg.HOMEUSER_STATUS_ERROR);
        }
        if (!byMobile.getPassword().equals(password)){
            return Result.error(CodeMsg.HOMEUSER_PASSWORD_ERROR);
        }
        SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, byMobile);
        return Result.success(true);

    }

    /**
     * 跳转到注册页面
     * @return
     */
    @RequestMapping(value="/register",method= RequestMethod.GET)
    public String register(){
        return "home/register";
    }

    /**
     * 用户注册
     * @param homeUser
     * @param code
     * @return
     */
    @RequestMapping(value="/register",method= RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> register(HomeUser homeUser, @RequestParam("reCode") String code) {
        //正则验证输入的手机号是否合法
        String checkPhone = "^1[3|4|5|7|8]\\d{9}$";
        Pattern r = Pattern.compile(checkPhone);
        Matcher m = r.matcher(homeUser.getMobile());
        if (!m.matches()) {
            return Result.error(CodeMsg.HOMEUSER_MOBILE_ERROR);
        }
        if (!StringUtil.emailFormat(homeUser.getEmail())) {
            return Result.error(CodeMsg.COMMON_EMAIL_FORMAET_ERROR);
        }
        if (code == null) {
            return Result.error(CodeMsg.HOMEUSER_CODE_ERROR);
        }
        if (code.length() != 4) {
            return Result.error(CodeMsg.HOMEUSER_CODE_LENGTH_ERROR);
        }
        Object attr = SessionUtil.get(SessionConstant.HOME_USER_REGISTER_CODE);
        if (attr == null) {
            return Result.error(CodeMsg.CODE_NOT_EMPTY);
	 * @param request
	 * @return
	 */
	public static boolean isAjax(HttpServletRequest request){
		String header = request.getHeader("X-Requested-With");
		if("XMLHttpRequest".equals(header))return true;
		return false;
	}
	
	/**
	 * 从流读取字符串
	 * @param inputStream
	 * @return
	 */
	public static String getStringFromInputStream(InputStream inputStream){
		String string = "";
		try {
			BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream,"GB2312"));
			String buf = null;
			try {
				while((buf = bufferedReader.readLine()) != null){
					string += buf;
				}
			} catch (Exception e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}finally{
				try {
					bufferedReader.close();
				} catch (IOException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
			}
		} catch (Exception e) {
			// TODO: handle exception
		}
		return string;
	}
	/**

    /**
     * 网点编辑页面
     * @param model
     * @return
     */
    @RequestMapping(value="/edit",method= RequestMethod.GET)
    public String edit(Model model, @RequestParam(name="id")Long id){
        model.addAttribute("roles", roleService.findAllByRoleType(UserRoleTypeEnum.BRANCHES));
        model.addAttribute("user", userService.find(id));
        return "admin/branches/edit";
    }

    /**
     * 编辑网点信息表单提交处理
     * @param user
     * @return
     */
    @RequestMapping(value="/edit",method= RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> edit(User user){
        //用统一验证实体方法验证是否合法
        CodeMsg validate = ValidateEntityUtil.validate(user);
        if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
            return Result.error(validate);
        }
        if(user.getRole() == null || user.getRole().getId() == null){
            return Result.error(CodeMsg.BRANCHES_USER_ROLE_EMPTY);
        }
        if(user.getId() == null || user.getId().longValue() <= 0){
            return Result.error(CodeMsg.BRANCHES_USE_NO_EXIST);
        }
        if(userService.isExistUsername(user.getUsername(), user.getId())){
            return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
        }
        //到这说明一切符合条件,进行数据库保存
        User findById = userService.find(user.getId());
        //讲提交的网点信息指定字段复制到已存在的user对象中,该方法会覆盖新字段内容
        BeanUtils.copyProperties(user, findById, "id","createTime","updateTime","userType");
        if(userService.save(findById) == null){
            return Result.error(CodeMsg.BRANCHES_USE_EDIT_ERROR);
        }
        if ("".equals(homeUserAddress.getMobile()) && "".equals(homeUserAddress.getPhone())) {
            return Result.error(CodeMsg.HOMEUSERADDRESS_MOBILE_PHONE_ERROR);
        }
        homeUserAddress.setHomeUser(homeUser);
        if (homeUserAddress.getIsDefault() == 0) {
            HomeUserAddress byIsDefault = homeUserAddressService.findByIsDefaultAndHomeUserTypeAndHomeUser_Id(
                    HomeUserAddress.DEFAULT,homeUserAddress.getHomeUserType(),homeUser.getId());
            if (byIsDefault != null) {
                byIsDefault.setIsDefault(1);
                if (homeUserAddressService.save(byIsDefault) == null) {
                    return Result.error(CodeMsg.HOMEUSERADDRESS_ADD_ERROR);
                }
            }
        }
        if (homeUserAddressService.save(homeUserAddress) == null) {
            return Result.error(CodeMsg.HOMEUSERADDRESS_ADD_ERROR);
        }
        return Result.success(true);
    }

    /**
     * 点击修改时弹出层要回显数据
     *
     * @param id
     * @return
     */
    @RequestMapping("/initializeForm")
    @ResponseBody
    public Result<HomeUserAddress> initializeForm(@RequestParam("id") Long id) {
        HomeUserAddress homeUserAddress = homeUserAddressService.find(id);
        return Result.success(homeUserAddress);
    }

    /**
     * 用户修改地址
     * @param homeUserAddress
     * @return
     */
    @RequestMapping("/update")
    @ResponseBody
    public Result<Boolean> update(HomeUserAddress homeUserAddress) {
        HomeUser homeUser = SessionUtil.getHomeUser();
        CodeMsg validate = ValidateEntityUtil.validate(homeUserAddress);
        if (validate.getCode() != CodeMsg.SUCCESS.getCode()) {
            return Result.error(validate);
        }
        if (homeUserAddress.getMobile() == null && homeUserAddress.getPhone() == null) {
            return Result.error(CodeMsg.HOMEUSERADDRESS_MOBILE_PHONE_ERROR);
        }
        if ("".equals(homeUserAddress.getMobile()) && "".equals(homeUserAddress.getPhone())) {
            return Result.error(CodeMsg.HOMEUSERADDRESS_MOBILE_PHONE_ERROR);
        }
public class HomeUserManagerController {

    @Autowired
    private HomeUserService homeUserService;
    @Autowired
    private HomeUserIdCardService homeUserIdCardService;

    /**
     * 跳转到个人中心首页
     * @param model
     * @return
     */
    @RequestMapping("/index")
    public String index(Model model) {
        HomeUser homeUser = SessionUtil.getHomeUser();
        model.addAttribute("homeUser", homeUser);
        model.addAttribute("index", 4);
        model.addAttribute("active", 0);
        return "home/user_manager/index";
    }

    /**
     * 修改个人信息
     * @param homeUser
     * @return
     */
    @RequestMapping("/update")
    @ResponseBody
    public Result<Boolean> update(HomeUser homeUser) {
        CodeMsg validate = ValidateEntityUtil.validate(homeUser);
        if (validate.getCode() != CodeMsg.SUCCESS.getCode()) {
            return Result.error(validate);
        }
        if (homeUserService.isExistMobile(homeUser.getName(), homeUser.getId())) {
            return Result.error(CodeMsg.HOMEUSER_MOBILE_EXIST);
        }
        HomeUser findById = homeUserService.find(homeUser.getId());
        //讲提交的管理员信息指定字段复制到已存在的user对象中,该方法会覆盖新字段内容
        BeanUtils.copyProperties(homeUser, findById, "id", "createTime", "updateTime", "password", "email");
        HomeUser save = homeUserService.save(findById);
        if (save == null) {
            return Result.error(CodeMsg.HOMEUSER_EDIT_ERROR);
        }
        SessionUtil.set(SessionConstant.SESSION_HOME_USER_LOGIN_KEY, save);
        return Result.success(true);
    }

    /**
     * 跳转到修改密码页面
                                PageBean<ExpressMailOrder> pageBean, Model model) {
        // rsolutionId  2已下单 3处理中  4已完成
        pageBean.setPageSize(5);
        model.addAttribute("pageBean", expressMailOrderService.selOrderState(pageBean, rsolutionId, waybillNumberStr));
        model.addAttribute("rsolutionId", rsolutionId);
        return "home/index/order_state_page";
    }

    /**
     * 删除快递订单
     *
     * @param id
     * @return
     */
    @RequestMapping(value = "/delete", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> delete(@RequestParam(name = "id", required = true) Long id) {
        try {
            expressMailOrderService.deleteById(id);
        } catch (Exception e) {
            return Result.error(CodeMsg.ADMIN_EXPRESSMAILORDER_DELETE_ERROR);
        }
        return Result.success(true);
    }

}

/**
		final Matcher mat = pattern.matcher(email);
		if (!mat.find()) {
			tag = false;
		}
		return tag;
	}

	/**
	 * 验证是否是手机号
	 * @param
	 * @return
	 */
	public static boolean  isMobile(String str) {
		Pattern p = null;
		Matcher m = null;
		boolean b = false;
		String s2="^1[0-9]{10}$";// 验证手机号
		if(StringUtils.isNotBlank(str)){
			p = Pattern.compile(s2);
			m = p.matcher(str);
			b = m.matches();
		}
		return b;
	}

	/**
	 * 验证是否是qq号
	 * @param qq
	 * @return
	 */
	public static boolean checkQQ(String qq) {
		//先验证是否为5—12位数字
		if(qq.length() < 5 || qq.length() > 12) {
			return false;
		}
		//首位不能是0
		if(qq.charAt(0) == '0') {
			return false;
		}
		//验证每一位数字都在1-9内
		for(int x = 0;x < qq.length();x++) {
			char ch = qq.charAt(x);
			if(ch < '0' || ch > '9') {
				return false;
			}
		}
		return true;
	}
	
	/**
	 * 身份证验证
	 * @param card
		if(user.getId() == null || user.getId().longValue() <= 0){
			return Result.error(CodeMsg.ADMIN_USE_NO_EXIST);
		}
		if(userService.isExistUsername(user.getUsername(), user.getId())){
			return Result.error(CodeMsg.ADMIN_USERNAME_EXIST);
		}
		//到这说明一切符合条件,进行数据库保存
		User findById = userService.find(user.getId());
		//讲提交的管理员信息指定字段复制到已存在的user对象中,该方法会覆盖新字段内容
		BeanUtils.copyProperties(user, findById, "id","createTime","updateTime","userType");
		if(userService.save(findById) == null){
			return Result.error(CodeMsg.ADMIN_USE_EDIT_ERROR);
		}
		operaterLogService.add("编辑管理员,管理员名:" + user.getUsername());
		return Result.success(true);
	}
	
	/**
	 * 删除管理员
	 * @param id
	 * @return
	 */
	@RequestMapping(value="/delete",method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> delete(@RequestParam(name="id",required=true)Long id){
		try {
			userService.delete(id);
		} catch (Exception e) {
			return Result.error(CodeMsg.ADMIN_USE_DELETE_ERROR);
		}
		operaterLogService.add("删除管理员,管理员ID:" + id);
		return Result.success(true);
	}
}

        return "admin/courier/add";
    }

    /**
     * 快递员添加表单提交处理
     * @param user
     * @return
     */
    @RequestMapping(value="/add",method= RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> add(User user){
        User loginedUser = SessionUtil.getLoginedUser();
        if (loginedUser.getUserType().getCode() != UserRoleTypeEnum.BRANCHES.getCode()){
            return Result.error(CodeMsg.COURIER_USER_ROLE_ERROR);
        }
        //用统一验证实体方法验证是否合法
        CodeMsg validate = ValidateEntityUtil.validate(user);
        if(validate.getCode() != CodeMsg.SUCCESS.getCode()){
            return Result.error(validate);
        }
        if(user.getRole() == null || user.getRole().getId() == null){
            return Result.error(CodeMsg.COURIER_USER_ROLE_EMPTY);
        }
        //判断快递员名是否存在
        if(userService.isExistUsername(user.getUsername(), 0L)){
            return Result.error(CodeMsg.COURIER_USERNAME_EXIST);
        }
        user.setUserType(UserRoleTypeEnum.COURIER);
        user.setBranchId(loginedUser.getId());
        //到这说明一切符合条件,进行数据库新增
        if(userService.save(user) == null){
            return Result.error(CodeMsg.COURIER_USE_ADD_ERROR);
        }
        operaterLogService.add("添加快递员,快递员名:" + user.getUsername());
        return Result.success(true);
    }

    /**
     * 快递员编辑页面
     * @param model
     * @return
     */
    @RequestMapping(value="/edit",method= RequestMethod.GET)
    public String edit(Model model, @RequestParam(name="id")Long id){
        model.addAttribute("roles", roleService.findAllByRoleType(UserRoleTypeEnum.COURIER));
        model.addAttribute("user", userService.find(id));
        return "admin/courier/edit";
    }

    /**
     * 编辑快递员信息表单提交处理
     * @param user
     * @return
     */
        operaterLogService.add("编辑网点,网点名:" + user.getUsername());
        return Result.success(true);
    }

}

/**
 * @info : 前台网点申请网点申请控制层
 */

@RequestMapping("/admin/branchApplyFor")
@Controller
public class BranchApplyForController {

    @Autowired
    private BranchApplyForService branchApplyForService;
    @Autowired
    private UserService userService;
    @Autowired
    private RoleService roleService;

    /**
     * 网点申请列表页面

/**
 * @info : 前台用户个人中心控制层
 */
@RequestMapping("/home/userManager")
@Controller
public class HomeUserManagerController {

    @Autowired
    private HomeUserService homeUserService;
    @Autowired
    private HomeUserIdCardService homeUserIdCardService;

    /**
     * 跳转到个人中心首页
     * @param model
     * @return
     */
    @RequestMapping("/index")
    public String index(Model model) {
        HomeUser homeUser = SessionUtil.getHomeUser();
        model.addAttribute("homeUser", homeUser);
        model.addAttribute("index", 4);
        model.addAttribute("active", 0);
        return "home/user_manager/index";
		//表示密码正确,接下来判断用户状态是否可用
		if(findByUsername.getStatus() == User.ADMIN_USER_STATUS_UNABLE){
			return Result.error(CodeMsg.ADMIN_USER_UNABLE);
		}
		//检查用户所属角色状态是否可用
		if(findByUsername.getRole() == null || findByUsername.getRole().getStatus() == Role.ADMIN_ROLE_STATUS_UNABLE){
			return Result.error(CodeMsg.ADMIN_USER_ROLE_UNABLE);
		}
		//检查用户所属角色的权限是否存在
		if(findByUsername.getRole().getAuthorities() == null || findByUsername.getRole().getAuthorities().size() == 0){
			return Result.error(CodeMsg.ADMIN_USER_ROLE_AUTHORITES_EMPTY);
		}
		//检查一切符合,可以登录,将用户信息存放至session
		request.getSession().setAttribute(SessionConstant.SESSION_USER_LOGIN_KEY, findByUsername);
		//销毁session中的验证码
		request.getSession().setAttribute("admin_login", null);
		//将登陆记录写入日志库
		operaterLogService.add("用户【"+user.getUsername()+"】于【" + StringUtil.getFormatterDate(new Date(), "yyyy-MM-dd HH:mm:ss") + "】登录系统!");
		log.info("用户成功登录,user = " + findByUsername);
		return Result.success(true);
	}
	
	/**
	 * 登录成功后的系统主页
	 * @param model
	 * @return
	 */
	@RequestMapping(value="/index")
	public String index(Model model){
		model.addAttribute("operatorLogs", operaterLogService.findLastestLog(10));
		BigDecimal homeUserCount = new BigDecimal(homeUserService.total());
		BigDecimal userCount = new BigDecimal(userService.total());
		BigDecimal homeUserCountAddUserCount = homeUserCount.add(userCount);
		model.addAttribute("branchesUsers",userService.inquiryOutletsUnderTheCourier());
		model.addAttribute("orderCountAndMonthByNowYearList",expressMailOrderService.orderCountAndMonthByNowYear());
		model.addAttribute("userTotal",homeUserCountAddUserCount);
		model.addAttribute("operatorLogTotal", operaterLogService.total());
		model.addAttribute("databaseBackupTotal", 0);
		model.addAttribute("onlineUserTotal", SessionListener.onlineUserCount);
		model.addAttribute("showTipsText", showTipsText);
		model.addAttribute("showTipsUrlText", showTipsUrlText);
		model.addAttribute("showTipsUtl", showTipsUtl);
		model.addAttribute("showTipsBtnText", showTipsBtnText);
		return "admin/system/index";
	}
	
	/**
	 * 注销登录
	 * @return
	 */
	@RequestMapping(value="/logout")
    @ResponseBody
    public Result<Boolean> defaultAddress(@RequestParam(name = "id") Long id) {
        HomeUser homeUser = SessionUtil.getHomeUser();
        HomeUserAddress homeUserAddress = homeUserAddressService.find(id);
        HomeUserAddress byIsDefault = homeUserAddressService.findByIsDefaultAndHomeUserTypeAndHomeUser_Id(
                HomeUserAddress.DEFAULT,homeUserAddress.getHomeUserType(),homeUser.getId());
        if (byIsDefault != null) {
            byIsDefault.setIsDefault(1);
            if (homeUserAddressService.save(byIsDefault) == null) {
                return Result.error(CodeMsg.HOMEUSERADDRESS_DEFAULT_ERROR);
            }
        }
        homeUserAddress.setIsDefault(0);
        if (homeUserAddressService.save(homeUserAddress) == null) {
            return Result.error(CodeMsg.HOMEUSERADDRESS_DEFAULT_ERROR);
        }
        return Result.success(true);
    }

}

/**
 * @info : 前台用户个人中心控制层
 */
@RequestMapping("/home/userManager")
@Controller
public class HomeUserManagerController {

    /**
     * 进行表单验证进行保存
     *
     * @param recipientsInfo
     * @return
     */
    @RequestMapping(value = "/saveAdd", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> saveAdd(String recipientsInfo) {
        List<ExpressMailOrder> expressMailOrders = JSONObject.parseArray(recipientsInfo, ExpressMailOrder.class);
        for (ExpressMailOrder expressMailOrder : expressMailOrders) {
            //进行实体类验证
            CodeMsg validate = ValidateEntityUtil.validate(expressMailOrder);
            if (validate.getCode() != CodeMsg.SUCCESS.getCode()) {
                return Result.error(validate);
            }
        }

        //验证成功进行保存
        if (expressMailOrderService.saveAll(expressMailOrders).equals(1)) {
            return Result.error(CodeMsg.ADMIN_EXPRESSMAILORDER_ADD_ERROR);
        }
        //保存成功返回成功消息
        return Result.success(true);
    }

    /**
     * 进行表单验证进行保存
     *
     * @param rsolutionId
     * @return
     */
    @RequestMapping(value = "/selOrderState", method = RequestMethod.POST)
    public String selOrderState(String rsolutionId, String waybillNumberStr,
                                PageBean<ExpressMailOrder> pageBean, Model model) {
        // rsolutionId  2已下单 3处理中  4已完成
        pageBean.setPageSize(5);
        model.addAttribute("pageBean", expressMailOrderService.selOrderState(pageBean, rsolutionId, waybillNumberStr));
     */
    @RequestMapping(value = "/updatePassword", method = RequestMethod.POST)
    @ResponseBody
    public Result<Boolean> updatePassword(HomeUser homeUser, @RequestParam("code") String code) {

        String checkPhone = "^1[3|4|5|7|8]\\d{9}$";
        Pattern r = Pattern.compile(checkPhone);
        Matcher m = r.matcher(homeUser.getMobile());
        if (!m.matches()) {
            return Result.error(CodeMsg.HOMEUSER_MOBILE_ERROR);
        }
        if (!StringUtil.emailFormat(homeUser.getEmail())) {
            return Result.error(CodeMsg.COMMON_EMAIL_FORMAET_ERROR);
        }
        if (code == null) {
            return Result.error(CodeMsg.HOMEUSER_CODE_ERROR);
        }
        if (code.length() != 4) {
            return Result.error(CodeMsg.HOMEUSER_CODE_LENGTH_ERROR);
        }
        Object attr = SessionUtil.get(SessionConstant.HOME_USER_UPDATE_PASSWORD_CODE);
        if (attr == null) {
            return Result.error(CodeMsg.CODE_NOT_EMPTY);
        }
        if (!code.equalsIgnoreCase(attr.toString())) {
            return Result.error(CodeMsg.CPACHA_ERROR);
        }
        //验证通过,更新密码
        HomeUser byId = homeUserService.findByMobile(homeUser.getMobile());
        byId.setPassword(homeUser.getPassword());
        if (homeUserService.save(byId) == null) {
            return Result.error(CodeMsg.HOMEUSER_FORGET_ERROR);
        }
        SessionUtil.set(SessionConstant.HOME_USER_UPDATE_PASSWORD_CODE, null);
        return Result.success(true);
    }

    /**
     * 跳转到实名认证页面
     *

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值