立即前往

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
查看全部活动
热门活动
  • 智算采购季 热销S6云服务器2核4G限时88元/年起,部分主机可加赠对象存储组合包!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 一键部署Llama3大模型学习机 0代码一键部署,预装最新主流大模型Llama3与StableDiffusion
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 产品能力
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
    • 关系数据库SQL Server版
    • 企业主机安全
    • 云防火墙
    • CDN加速
    • 物理机
    • GPU云主机
    • 天翼云电脑(政企版)
    • 天翼云电脑(公众版)
    • 云主机备份
    • 弹性云主机
      搜索发现
      关系数据库SQL Server版企业主机安全云防火墙CDN加速物理机GPU云主机天翼云电脑(政企版)天翼云电脑(公众版)云主机备份弹性云主机
    • 文档
    • 控制中心
    • 备案
    • 管理中心
    • 登录
    • 免费注册

    Spring系列之Spring MVC知识

    首页 知识中心 软件开发 文章详情页

    Spring系列之Spring MVC知识

    2024-09-25 10:14:09 阅读次数:435

    MVC,Spring

    MVC概述

    MVC模式就是架构模式的一种,Model(模型)、View(视图)和Controller(控制)组成,MVC结构可以分成三层:

    1. 最上面的一层,是直接面向最终用户的视图层View。它是提供给用户的操作界面,是程序的外壳
    2. 最底下的一层,是核心的数据层Model,也就是程序需要操作的数据或信息
    3. 中间的一层,是控制层Controller,它负责根据用户从视图层输入的指令,选取数据层中的数据,然后对其进行相应的操作,产生最终结果

    这三层是紧密联系在一起的,但又是互相独立的,每一层内部的变化不影响其他层。每一层都对外提供接口,供上面一层调用,实现模块化。

    MVC和MVP

    MVP,Model负责数据处理;View负责呈现界面;Presenter负责业务功能,将Model层的数据安全送往View层。Model和View是不能互通的,需要经过中间的Presenter进行传递,这一点不同于MVC模式。MVC模式中View可以直接获取并操作数据,造成View层对数据层的关联。
    相比于MVC模式,MVP模式具有更加严格的分层和清晰的结构,这种分层方式更能保证各个层次尽量少的依赖。从MVP的架构来看,Model层逻辑具有高独立性,但Model层需要依赖数据、网络、设备等外部因素。Presenter层依赖于Model和View,而View层依赖于Presenter层和设备。

    技巧

    Controller

    在开发MVC应用时,第一步便是编写Controller,方法有4种:

    1. 使用Spring MVC提供的针对特定目的而设计的控制器类(不常用):
    • AbstractUrlViewController
    • MultiActionController
    • ParameterizableViewController
    • ServletForwardingController
    • ServletWrappingController
    • UrlFilenameViewController
    1. 使用注解@Controller配置(代码略)
    2. 实现Controller接口并重写​​handleRequest()​​方法:
    public class DemoController implements Controller {
        @Override
        public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
            return new ModelAndView("main");
        }
    }

    同时需要添加配置:​​<bean name="/main" class="aa.bb.DemoController"/>​​

    1. 若要控制受支持的HTTP方法,会话和内容缓存,还可以继承AbstractController并重写方法handleRequestInternal:
    public class BigController extends AbstractController {
        @Override
        protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response) throws Exception {
            return new ModelAndView("big");
        }
    }

    同时配置:

    <bean name="/big" >
        <property name="supportedMethods" value="POST"/>
    </bean>

    @RequestMapping

    @RequestMapping可用于指定一个方法要处理的多个URL模式:

    @RequestMapping({"/hello", "/hi", "/greetings"})

    @RequestMapping可以指定RequestMethod,如RequestMethod.GET;此时可用@GetMapping代替,即等价于​​@RequestMapping(method = {RequestMethod.GET})​​

    RequestParam

    ModelAndView和ModelMap

    ModelAndView对象有两个作用:

    1. 设置转向地址
      ​​​ModelAndView view = new ModelAndView("path:ok");​​
    2. 用于传递控制方法处理结果数据到结果页面,也就是说把需要在结果页面上展示的数据放到ModelAndView对象中即可,作用类似于request对象的setAttribute方法的作用,用来在一个请求过程中传递处理的数据。通过以下方法向页面传递参数:
      ​​​addObject(String key,Object value);​​ 在页面上可以通过el变量方式$key或者bboss的一系列数据展示标签获取并展示ModelAndView中的数据。

    Model 是一个接口, 其实现类为ExtendedModelMap,继承ModelMap类。
    ModelMap对象主要用于传递控制方法处理数据到结果页面,也就是说把结果页面上需要的数据放到ModelMap对象中即可,作用类似于request对象的setAttribute方法的作用,用来在一个请求过程中传递处理的数据。通过以下方法向页面传递参数:
    ​​​addAttribute(String key,Object value);​​ 在页面上可以通过el变量方式$key或者bboss的一系列数据展示标签获取并展示modelmap中的数据。

    ModelMap本身不能设置页面跳转的url地址别名或者物理跳转地址,可以通过控制器方法的返回值来设置跳转url地址别名或者物理跳转地址。
    ModelMap的实例是由Spring mvc框架自动创建并作为控制器方法参数传入,用户无需自己创建。

    两者区别

    1. ModelAndView可以设置转向地址
    2. ModelAndView的实例是由用户手动创建的

    Spring的控制器Controller会返回一个ModelAndView的实例,包括View和Model信息,视图是以名字为标识的,ViewResolver是通过名字来解析view的。

    如果方法添加注解@ResponseBody ,则会直接将返回值输出到页面。

    ViewResolver,视图解析器,提供从视图名称到实际视图的映射。

    文件上传

    @RequestMapping(value = "/uploadFiles", method = RequestMethod.POST)
    public String fileUpload(@RequestParam CommonsMultipartFile[] fileUpload) throws Exception {
        for (CommonsMultipartFile item : fileUpload){
            // 存储上传的文件
            item.transferTo(new File(item.getOriginalFilename()));
        }
        return "Success";
    }

    通过自动将上传数据绑定到CommonsMultipartFile对象数组,默认使用Apache Commons FileUpload作为文件解析器。

    文件下载

    HttpServletRequest和HttpServletResponse

    示例代码:

    @RequestMapping("/download")
    public String doDownloadFile(HttpServletRequest request, HttpServletResponse response) {
        // 访问请求/响应
        return "";
    }

    Spring检测并自动将HttpServletRequest和HttpServletResponse对象注入方法中。

    WebFlux & Spring MVC

    WebFlux不是Spring MVC的替代方案,WebFlux 也可以运行在Servlet容器上(Servlet 3.1+),WebFlux主要还是应用在异步非阻塞编程模型,而 Spring MVC 是同步阻塞的。两者可以混合使用。

    函数式编程

    异常处理

    如果没有统一异常处理,或需要做个性化的异常处理,实例:

    /**
     * 接口附带异常处理逻辑.
     *
     * @param userService the user service
     * @return the user by name with error handle
     */
    public RouterFunction<ServerResponse> withErrorHandle() {
        return RouterFunctions.route()
                .GET("/userwitherrorhandle/{username}",
                        request -> ServerResponse.ok()
                          .body(userService.getByName(request.pathVariable("username"))))
                // 异常处理
                .onError(RuntimeException.class,
                        (e, request) -> EntityResponse.fromObject(e.getMessage())
                                .status(HttpStatus.INTERNAL_SERVER_ERROR)
                                .build())
                .build();
    }

    onError 方法及其重载方法进行接口的异常处理。

    过滤器

    通过 filter 方法可以实现日志、安全策略、跨域等功能:

    /**
     * 对特定接口指定过滤器.
     *
     * @param userService the user service
     * @return the router function
     */
    public RouterFunction<ServerResponse> withFilter() {
        return RouterFunctions.route().POST("/save",
                request -> ServerResponse.ok()
                        .body(userService.saveUser(request.body(UserInfo.class))))
                // 执行过滤器逻辑 参数携带 save 放行 否则返回 bad request 并附带消息
                .filter((request, next) -> request.param("save").isPresent() ?
                        next.handle(request) :
                        ServerResponse.status(HttpStatus.BAD_REQUEST).body("no save"))
                .build();
    }

    拦截器

    提供类似过滤器前置/后置处理机制,before 和 after 方法将分别进行前置和后置处理,可达到相同效果:

    public RouterFunction<ServerResponse> getUserByName() {
        return RouterFunctions.route()
                .GET("/user/{username}",
                        request -> ServerResponse.ok()
                         .body(userService.getByName(request.pathVariable("username"))))
                // 前置处理 打印 path
                .before(serverRequest -> {
                    (serverRequest.path());
                    return serverRequest;
                })
                // 后置处理 如果响应状态为200 则打印 response ok
                .after(((serverRequest, serverResponse) -> {
                    if (serverResponse.statusCode() == HttpStatus.OK) {
                        ("response ok");
                    }
                    return serverResponse;
                })).build();
    }

    统一处理

    @Bean
    RouterFunction<ServerResponse> userEndpoints(UserController userController) {
        return RouterFunctions.route()
                .path("/v2/user", builder -> builder
                    .add(userController.getUserByName()
                    .and(userController.delUser()
                    .and(userController.saveUser()
                    .and(userController.updateUser())))))
                .build();
    }
    @Bean
    RouterFunction<ServerResponse> nestEndpoints(UserController userController) {
        return RouterFunctions.route().nest(RequestPredicates.path("/v1/user"),
                builder -> builder
                        .add(userController.getUserByName())
                        .add(userController.delUser())
                        .add(userController.saveUser())
                        .add(userController.updateUser()))
                // 对上述路由进行统一异常处理
                .onError(RuntimeException.class,
                        (throwable, serverRequest) -> ServerResponse
                                .status(HttpStatus.BAD_REQUEST)
                                .body("bad req"))
                .build();
    }

    进阶

    web.xml中listener、filter和servlet的初始化顺序

    顺序:​​listener -> filter -> servlet​​​ 对使用​​<listener>​​标签声明的监听器类进行实例化,调用监听器类实例对象的​​contextInitialized()​​方法,初始化应用上下文数据;其次对使用​​<filter>​​标签声明的过滤器类进行实例化,调用过滤器类实例对象的​​init()​​方法;如果​​<servlet>​​标签内使用​​<load-on-startup>​​标签,则按照数值从小到大的顺序对Servlet进行实例化,并调用对应的​​init()​​方法。

    applicationContext.xml如何自动加载

    当运行一个Web项目时,应用服务器(如Tomcat)首先会读取项目源码路径中的​​web.xml​​​文件,解析其中的配置,发现配置ContextLoaderListener,因此会执行ContextLoaderListener类中的contextInitialized方法,在这个方法中会调用initWebApplicationContext()方法,用于初始化一个WebApplicationContext,即初始化一个Web应用下的Spring容器。在initWebApplicationContext()方法后续代码实现的内部会根据​​web.xml​​​中配置的contextConfigLocation属性加载指定的​​applicationContext.xml​​​文件,根据这个文件初始化Spring容器。若没配置contextConfigLocation参数,那么应用启动时会默认查找应用根目录下​​/WEB-INF/applicationContext.xml​​文件,也就是说这是一个默认加载的文件路径

    DispatcherServlet

    SpringMVC的核心分发器,实现请求分发,是处理请求的入口。DispatcherServlet是一个Servlet,在应用启动时,DispatcherServlet初始化会执行init方法,DispatcherServlet的init方法继承自HttpServletBean,在这个初始化方法中会实例化一个WebApplicationContext对象,并且将初始化后的context存到ServletContext中,让Servlet和Spring容器进行关联。在DispatcherServlet的onRefresh方法中,初始化各种请求处理策略,如文件上传处理策略、URL请求处理策略、视图映射处理策略、异常处理策略等,这些策略的大部分执行逻辑都是先从WebApplicationContext中查找,找不到的情况下再加载和DispatcherServlet同目录下的DispatcherServlet.properties中的各个策略,例如初始化HandlerMapping,注册各种请求的处理策略及处理类。

    SpringMVC框架在启动的时候会遍历Spring容器中的所有bean,对标注@Controller或@RequestMapping注解的类中方法进行遍历,将类和方法上的@RequestMapping注解值进行合并,使用@RequestMapping注解的相关参数值(如value、method等)封装一个RequestMappingInfo,将这个Controller实例、方法及方法参数信息(类型、注解等)封装到HandlerMethod中,然后以RequestMappingInfo为key,HandlerMethod为value存到一个以Map为结构的handlerMethods中。

    接着将@RequestMapping注解中的value(即请求路径)值取出,即url,然后以url为key,以RequestMappingInfo为value,存到一个以Map为结构的urlMap属性中。

    客户端发起请求时,根据请求的URL到urlMap中查找,找到RequestMappingInfo,然后根据RequestMappingInfo到handlerMethods中查找,找到对应的HandlerMethod,接着将HandlerMethod封装到HandlerExecutionChain;接着遍历容器中所有HandlerAdapter实现类,找到支持这次请求的HandlerAdapter,如RequestMappingHandlerAdapter,然后执行SpringMVC拦截器的前置方法(preHandle方法),然后对请求参数解析及转换,然后(使用反射)调用具体Controller的对应方法返回一个ModelAndView对象,执行拦截器的后置方法(postHandle方法),然后对返回的结果进行处理,最后执行afterCompletion方法。

    版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/u_15851118/5805381,作者:johnny233,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

    上一篇:Linux:ansible-playbook配置文件(剧本)(进阶)

    下一篇:使用java底层实现邮件的发送(含测试,源码)

    相关文章

    2025-04-22 09:28:19

    61. Spring事务传播行为实现原理

    61. Spring事务传播行为实现原理

    2025-04-22 09:28:19
    Spring , ThreadLocal , 事务
    2025-04-18 07:10:30

    深入解析 Spring Security —— 打造高效安全的权限管理体系

    Spring Security 是一个专注于认证与授权的安全框架,致力于保护 Web 应用程序的资源安全。通过高度灵活的配置和模块化的设计,它能够满足各种复杂的安全需求。

    2025-04-18 07:10:30
    Security , Spring , 权限 , 用户 , 角色 , 认证 , 配置
    2025-04-18 07:09:19

    深入理解Spring中的Bean循环依赖与解决机制

    Bean循环依赖是指两个或多个Bean之间相互依赖,形成依赖闭环的情况。例如,Bean A依赖Bean B,而Bean B又依赖Bean A。这种情况下,如果没有特殊处理,容器将无法正确初始化这些Bean,从而导致应用启动失败。

    2025-04-18 07:09:19
    Bean , Spring , 依赖 , 初始化 , 循环 , 缓存 , 解决
    2025-04-01 10:28:07

    Spring Boot 多环境开发配置详解:Profiles 的使用指南

    Spring Boot 多环境开发配置详解:Profiles 的使用指南

    2025-04-01 10:28:07
    application , profile , Spring , yml , 文件 , 环境 , 配置
    2025-04-01 10:16:07

    深入解析 Spring Bean 的生命周期

    深入解析 Spring Bean 的生命周期

    2025-04-01 10:16:07
    Bean , Spring , 初始化 , 执行 , 接口 , 生命周期
    2025-03-31 08:58:01

    探秘 Spring Application 启动流程:从初始化到运行的全景解析

    探秘 Spring Application 启动流程:从初始化到运行的全景解析

    2025-03-31 08:58:01
    Spring , 上下文 , 加载 , 启动 , 容器 , 应用
    2025-03-28 07:42:20

    Spring IOC 容器初始化流程深度解析

    Spring IOC 容器初始化流程深度解析

    2025-03-28 07:42:20
    Bean , IOC , Spring , 初始化 , 加载 , 容器
    2025-03-27 09:34:39

    时光机启动:Spring中如何巧妙实现定时任务?

    Spring框架通过@Scheduled注解和TaskScheduler接口为我们提供了定时任务的实现方式。

    2025-03-27 09:34:39
    Spring , 任务 , 定时 , 注解
    2025-03-26 10:18:58

    28. SpringBoot启动时的Banner设置【从零开始学Spring Boot

    28. SpringBoot启动时的Banner设置【从零开始学Spring Boot

    2025-03-26 10:18:58
    Boot , MyBatis , Spring , 升级 , 注解
    2025-03-25 08:08:18

    Spring 家族的三剑客:深入解析 Spring Framework 、 Spring Boot 与 Spring MVC 的区别

    Spring 家族的三剑客:深入解析 Spring Framework 、 Spring Boot 与 Spring MVC 的区别

    2025-03-25 08:08:18
    Boot , MVC , Spring , View , Web , 应用
    查看更多
    推荐标签

    作者介绍

    天翼云小翼
    天翼云用户

    文章

    32777

    阅读量

    4806328

    查看更多

    最新文章

    61. Spring事务传播行为实现原理

    2025-04-22 09:28:19

    深入解析 Spring Security —— 打造高效安全的权限管理体系

    2025-04-18 07:10:30

    深入理解Spring中的Bean循环依赖与解决机制

    2025-04-18 07:09:19

    Spring Boot 多环境开发配置详解:Profiles 的使用指南

    2025-04-01 10:28:07

    深入解析 Spring Bean 的生命周期

    2025-04-01 10:16:07

    探秘 Spring Application 启动流程:从初始化到运行的全景解析

    2025-03-31 08:58:01

    查看更多

    热门文章

    使用Spring的AOP时报错“ClassCastException: com.sun.proxy.$Proxy5 cannot be cast to com.demo.aop.Target“

    2023-06-14 09:12:07

    《Spring Cloud Config官方文档》之推送通知和Spring Cloud总线

    2022-11-08 07:33:17

    Ajax续

    2023-07-11 08:55:43

    Spring-AOP

    2023-05-25 14:43:25

    《Spring Boot官方指南》28.安全

    2023-02-15 10:01:11

    Spring-AOP的通知类型

    2023-07-06 09:42:12

    查看更多

    热门标签

    java Java python 编程开发 开发语言 代码 算法 线程 html Python 数组 C++ javascript c++ 元素
    查看更多

    相关产品

    弹性云主机

    随时自助获取、弹性伸缩的云服务器资源

    天翼云电脑(公众版)

    便捷、安全、高效的云电脑服务

    对象存储

    高品质、低成本的云上存储服务

    云硬盘

    为云上计算资源提供持久性块存储

    查看更多

    随机文章

    【Spring】—— 如何使用AOP(面向切面编程)?

    【设计模式-2.2】创建型——简单工厂和工厂模式

    Java 应用容器化:Spring Boot 与 Docker 的结合

    SpringBoot2.2发布,有哪些变化先知晓

    Spring Cloud Alibaba 新一代微服务解决方案

    Spring Boot的exit code

    • 7*24小时售后
    • 无忧退款
    • 免费备案
    • 专家服务
    售前咨询热线
    400-810-9889转1
    关注天翼云
    • 权益商城
    • 天翼云APP
    • 天翼云微信公众号
    服务与支持
    • 备案中心
    • 售前咨询
    • 智能客服
    • 自助服务
    • 工单管理
    • 客户公告
    • 涉诈举报
    账户管理
    • 管理中心
    • 订单管理
    • 余额管理
    • 发票管理
    • 充值汇款
    • 续费管理
    快速入口
    • 权益商城
    • 文档中心
    • 最新活动
    • 免费试用
    • 信任中心
    • 天翼云学堂
    云网生态
    • 甄选商城
    • 渠道合作
    • 云市场合作
    了解天翼云
    • 关于天翼云
    • 天翼云APP
    • 服务案例
    • 新闻资讯
    • 联系我们
    热门产品
    • 云电脑
    • 弹性云主机
    • 云电脑政企版
    • 天翼云手机
    • 云数据库
    • 对象存储
    • 云硬盘
    • Web应用防火墙
    • 服务器安全卫士
    • CDN加速
    热门推荐
    • 云服务备份
    • 边缘安全加速平台
    • 全站加速
    • 安全加速
    • 云服务器
    • 云主机
    • 智能边缘云
    • 应用编排服务
    • 微服务引擎
    • 共享流量包
    更多推荐
    • web应用防火墙
    • 密钥管理
    • 等保咨询
    • 安全专区
    • 应用运维管理
    • 云日志服务
    • 文档数据库服务
    • 云搜索服务
    • 数据湖探索
    • 数据仓库服务
    友情链接
    • 中国电信集团
    • 189邮箱
    • 天翼企业云盘
    • 天翼云盘
    ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
    公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
    • 用户协议
    • 隐私政策
    • 个人信息保护
    • 法律声明
    备案 京公网安备11010802043424号 京ICP备 2021034386号