xml 格式化

运行效果:免费在线XML格式化工具 - XML代码美化/压缩/验证

代码实现:

using Microsoft.AspNetCore.Mvc;
using System.Xml;
using System.Xml.Linq;namespace SaaS.OfficialWebSite.Web.Controllers
{public class XmlController : Controller{public IActionResult Index(){return View();}[HttpPost]public IActionResult ProcessXml([FromBody] XmlProcessRequest request){try{// 验证请求if (string.IsNullOrWhiteSpace(request.Xml)){return BadRequest(new { success = false, error = "XML内容不能为空" });}// 根据不同操作处理XMLswitch (request.Action.ToLower()){case "validate":return ValidateXml(request.Xml);case "format":return FormatXml(request.Xml, request.Options);case "minify":return MinifyXml(request.Xml);default:return BadRequest(new { success = false, error = "不支持的操作类型" });}}catch (Exception ex){return BadRequest(new { success = false, error = ex.Message });}}private IActionResult ValidateXml(string xml){try{// 尝试加载XML来验证XDocument.Parse(xml);return Ok(new { success = true });}catch (XmlException ex){return Ok(new { success = false, error = $"XML验证失败 (行 {ex.LineNumber}, 位置 {ex.LinePosition}): {ex.Message}" });}}private IActionResult FormatXml(string xml, XmlFormatOptions options){try{var doc = XDocument.Parse(xml);var settings = new XmlWriterSettings{Indent = true,IndentChars = options.Indent == "tab" ? "\t" : new string(' ', int.Parse(options.Indent)),NewLineChars = "\n",NewLineHandling = NewLineHandling.Replace,OmitXmlDeclaration = doc.Declaration == null};using (var writer = new StringWriter())using (var xmlWriter = XmlWriter.Create(writer, settings)){doc.Save(xmlWriter);xmlWriter.Flush(); var formattedXml = writer.ToString();// 如果需要排序属性if (options.SortAttributes){formattedXml = SortAttributes(formattedXml);}return Ok(new { success = true, formattedXml = formattedXml });}}catch (Exception ex){return BadRequest(new { success = false, error = ex.Message });}}private IActionResult MinifyXml(string xml){try{var doc = XDocument.Parse(xml);var settings = new XmlWriterSettings{Indent = false,NewLineHandling = NewLineHandling.None,OmitXmlDeclaration = doc.Declaration == null};using (var writer = new StringWriter())using (var xmlWriter = XmlWriter.Create(writer, settings)){doc.Save(xmlWriter);xmlWriter.Flush();return Ok(new { success = true, formattedXml = writer.ToString() });}}catch (Exception ex){return BadRequest(new { success = false, error = ex.Message });}}private string SortAttributes(string xml){var doc = XDocument.Parse(xml);foreach (var element in doc.Descendants()){if (element.HasAttributes){var orderedAttributes = element.Attributes().OrderBy(attr => attr.Name.LocalName).ToList();element.Attributes().Remove();element.Add(orderedAttributes);}}return doc.ToString();}}public class XmlProcessRequest{public string Xml { get; set; }public string Action { get; set; } // "format", "validate", "minify"public XmlFormatOptions Options { get; set; }}public class XmlFormatOptions{public string Indent { get; set; } = "4"; // "2", "4", "tab"public bool SortAttributes { get; set; } = true;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/92436.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/92436.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Pygame音频播放的最简框架代码示例

一、示例代码:import pygame pygame.init() pygame.mixer.init() pygame.mixer.music.load(/home/lijiang/Music/Lynyrd Skynyrd - Sweet Home Alabama.mp3) pygame.mixer.music.play()while pygame.mixer.music.get_busy():pygame.time.Clock().tick(10)二、代码详…

在Ubuntu环境中安装Docker和Minikube的完整指南

目录 前言 准备工作 第一部分:安装Docker 步骤1:卸载旧版本(如果有) 步骤2:安装依赖包 步骤3:添加Docker官方GPG密钥 步骤4:设置Docker仓库 步骤5:安装Docker引擎 步骤6&am…

几个概率分布在机器学习应用示例

一、说明 在这份快速指南中,我们将介绍最重要的分布——从始终公平的均匀分布,到钟形的正态分布,计数点击的泊松分布,以及二元选择的二项分布。 没有复杂的数学,只有清晰的概念、真实的例子,以及为什么它们…

2025年测绘程序设计模拟赛一--地形图图幅编号及图廓点经纬度计算

想要在2026年参加这个比赛的,可以加入小编和其它大佬所建的群242845175一起来备赛,为2026年的比赛打基础,也可以私信小编,为你答疑解惑一、读取文件 这里有两种文件需要读取,所以要额外处理 internal class Read {publ…

【C++基础】名字空间与 inline 命名空间:面试高频考点与真题解析

想象一下,你正在开发一个大型项目,团队中有10名程序员同时工作。当你们分别定义了calculate()函数时,编译器会陷入混乱:它不知道应该调用哪个版本的calculate。这就是C++引入名字空间(Namespace)的根本原因! 一、名字空间(Namespace)基础概念 1.1 为什么需要名字空间…

Pytest项目_day08(setup、teardown前置后置操作)

setup模块级setup_module:运行于模块开始之前,生效一次 一个py文件(测试文件)就是一个模块函数级setup_function:对于每条(不在类中的)函数用例生效,如果函数在类中,那么…

trae开发c#

安装插件C# Dev Kit,使用的版本是1.41.11 .NET Install Tool一般会自动安装,安装C# dev kit的时候,版本2.3.7 C# 插件,版本2.87.31 https://marketplace.visualstudio.com/items?itemNamems-dotnettools.vscode-dotnet-runtim…

Modstart 请求出现 Access to XMLHttpRequest at ‘xx‘

在 uniapp 前端页面请求时出现类似如下错误Access to XMLHttpRequest at https://example.com/api/mtiku/config from origin http://localhost:20000 has been blocked by CORS policy: Response to preflight request doesnt pass access control check: No Access-Control…

计算机视觉CS231n学习(5)

循环神经网络 RNN recurrent neural networksRNN序列处理能力(RNN核心作用) RNN处理序列数据,相比“Vanilla”神经网络(仅支持一对一映射),RNN支持多种序列映射模式: 一对一:传统分类…

Spring Boot Redis 缓存完全指南

Spring Boot Redis 缓存完全指南 1. 项目依赖配置 1.1 Maven依赖 <dependencies><!-- Spring Boot Redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><…

八股——WebSocket

文章目录1、 什么是 WebSocket&#xff1f;与 Http 协议的区别是什么&#xff1f;2、 Http 是如何升级为 WebSocket 的&#xff1f;3、 为什么 WebSocket 可以进行全双工模式的消息传输&#xff0c;而 Http 不可以&#xff1f;4、 什么是 TCP 的沾包和拆包&#xff1f;5、 WebS…

Mysql 如何使用 binlog 日志回滚操作失误的数据

文章目录一、背景二、准备测试数据1. 创建测试表2. 创建测试数据三、模拟误操作四、数据回滚&#xff08;一&#xff09;方案一&#xff1a;云数据库恢复&#xff08;二&#xff09;方案二&#xff1a;手动恢复1. 查询 binlog 日志2. 找到删除语句&#xff0c;手动还原为插入语…

wodpress结构化数据对SEO的作用

在 WordPress 网站中&#xff0c;结构化数据对 SEO 的作用主要体现在以下几个方面&#xff1a; 1. 提升搜索结果的可见性 结构化数据能够帮助搜索引擎更好地理解网页内容&#xff0c;从而以更精准的方式展示搜索结果。通过添加结构化数据&#xff0c;网页可以在搜索结果中显示…

讲一讲@ImportResource

题目详细答案ImportResource是 Spring 框架中的一个注解&#xff0c;用于将传统的 XML 配置文件导入到基于 Java 配置的 Spring 应用程序中。它允许开发者在使用 Java 配置的同时&#xff0c;继续利用现有的 XML 配置文件。这样可以逐步迁移旧的 XML 配置&#xff0c;或者在某些…

解决 Nginx 反代中 proxy_ssl_name 环境变量失效问题:网页能打开但登录失败

前言&#xff1a;在现代企业架构中&#xff0c;多域名反向代理是实现业务隔离、品牌独立的常见方案。然而&#xff0c;看似简单的Nginx配置背后&#xff0c;隐藏着与TLS协议、后端认证逻辑深度绑定的细节陷阱。本文将从原理到实践&#xff0c;详解为何在多域名场景下&#xff0…

三步完成,A100本地vLLM部署gpt-oss,并启动远程可访问api

A100本地vLLM部署gpt-oss&#xff0c;并启动远程可访问api GPT-oss试用 gpt-oss有两个原生配置是目前&#xff08;2025-8-8&#xff09;Ampere系列显卡不支持的&#xff0c;分别是默认的MXFP4量化&#xff0c;以及Flash-attn V3。官方给出的vllm教程也是默认使用的是H系列显卡…

【华为机试】63. 不同路径 II

文章目录63. 不同路径 II题目描述示例 1&#xff1a;示例 2&#xff1a;提示&#xff1a;解题思路核心思想&#xff1a;动态规划&#xff08;避开障碍&#xff09;算法流程复杂度分析边界与细节方法对比代码实现Go 实现&#xff08;含二维DP / 一维DP / 记忆化&#xff09;测试…

C++ 模拟实现 map 和 set:掌握核心数据结构

C 模拟实现 map 和 set&#xff1a;掌握核心数据结构 文章目录C 模拟实现 map 和 set&#xff1a;掌握核心数据结构一、set 和 map 的结构1.1 set的结构1.2 map的结构二、对红黑树的改造2.1 改造红黑树的节点2.2 改造红黑树2.2.1 仿函数的使用2.2.2 插入函数的改造2.2.3 删除函…

根据ASTM D4169-23e1标准,如何选择合适的流通周期进行测试?

根据ASTM D4169-23e1标准及行业实践&#xff0c;选择流通周期&#xff08;DC&#xff09;需综合以下因素&#xff1a;一、核心选择依据‌产品属性与包装形式‌‌重量体积‌&#xff1a;轻小包裹&#xff08;<4.53kg且<0.056m&#xff09;适用DC2/3/4/6/9/13-17等周期&…

MySQL的触发器:

目录 触发器的概念&#xff1a; 创建触发器&#xff1a; 查看触发器&#xff1a; 查看当前数据库的所有触发器的定义&#xff1a; 查看当前数据中某个触发器的定义&#xff1a; 从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息…