Bladeren bron

escape xml attrs/text

Martin Kunz 1 jaar geleden
bovenliggende
commit
6859071114
2 gewijzigde bestanden met toevoegingen van 20 en 4 verwijderingen
  1. 1 1
      src/components/TheModels.vue
  2. 19 3
      src/util/XmlElem.ts

+ 1 - 1
src/components/TheModels.vue

@@ -33,7 +33,7 @@ function downloadBlob(blob: Blob, filename: string) {
       </p>
     </div>
   </div>
-  <a   @click.prevent="exportProject()" >export</a>
+  <button class="btn btn-light" type="submit" @click.prevent="exportProject()">Export</button>
 </div>
 </template>
 

+ 19 - 3
src/util/XmlElem.ts

@@ -21,21 +21,37 @@ export class XMLElem {
 
     public toString(level: number=0): string {
         let s=" ".repeat(level+1) + `<${this.name} `;
-        for(const attr of this.attributes) 
-            s+=`${attr.name}="${attr.value}" `;
+        for(const attr of this.attributes) {
+            if(attr.value==undefined)
+                continue;
+            s+=`${attr.name}="${this.escapeXml(attr.value)}" `;
+        }
         s=s.slice(0, -1);
         s+=`>`
         for(const elem of this.elements) {
             s+="\n"+" ".repeat(level) + elem.toString(level+1);
         }
         if(this.value && this.elements.length==0) {
-            s+=this.value;
+            s+=this.escapeXml(this.value);
         }
         if(this.elements.length>0)
             s+=" ".repeat(level);
         s+=`</${this.name}>\n`
         return s;
     }
+
+    private escapeXml(unsafe: string) {
+        return unsafe.replace(/[<>&'"]/g, (c: string):string => {
+            switch (c) {
+                case '<': return '&lt;';
+                case '>': return '&gt;';
+                case '&': return '&amp;';
+                case '\'': return '&apos;';
+                case '"': return '&quot;';
+            }
+            return c;
+        });
+    }
 }
 
 class XmlAttr {