BASE64 转图像 angular 2
BASE64 to image angular 2
我正在尝试使用 angular 显示从远程服务器获取的图像 2.
在我的组件中,我有一个对象,它是一个 "university_info" 对象,它是我的模型。
export class myClass
{
university_info : university_info;
}
myFunction()
{
this.university_info = new university_info(responseFromServer[image])
}
export class university_info
{
imageBase64 : string
constructor(image : string)
{
this.imageBase64 = image
}
}
一切正常。我得到了 base64 图像,但是当我尝试以这种方式在 HTML 中显示它时:
<img [src]="'data:image/jpg;base64,'+university_info.imageBase64" />
这就是我得到的:
您可以尝试使用 _sanitizer.bypassSecurityTrustUrl
告诉 angular src
值是安全的。看看这个 class 来自 angular:
class DomSanitizationService {
sanitize(context: SecurityContext, value: any) : string
bypassSecurityTrustHtml(value: string) : SafeHtml
bypassSecurityTrustStyle(value: string) : SafeStyle
bypassSecurityTrustScript(value: string) : SafeScript
bypassSecurityTrustUrl(value: string) : SafeUrl
bypassSecurityTrustResourceUrl(value: string) : SafeResourceUrl
}
并以低安全为例 html:
export class AppComponent {
private _htmlProperty: string = '<input type="text" name="name">';
public get htmlProperty() : SafeHtml {
return this._sanitizer.bypassSecurityTrustHtml(this._htmlProperty);
}
constructor(private _sanitizer: DomSanitizationService){}
}
您必须确保 university_info.imageBase64
是 字符串类型 然后您的代码才能正常工作。
DEMO : http://plnkr.co/edit/pI35tx9gXZFO1sXj9Obm?p=preview
import {Component,ViewChild,Renderer,ElementRef,ContentChildren} from '@angular/core';
@Component({
selector: 'my-app',
template: `
<img [src]="'data:image/jpg;base64,'+imagePath"/>
`
})
export class App {
imagePath:string="iVBORw0KG...";
}
这个问题的 google 排名很高,所以我想我应该把我的发现放在这里。使用数据绑定设置图像的 [src]
属性 可能会出现问题,尤其是在某些较旧的移动设备上。因此,如果您在使用消毒剂+绑定方法时遇到性能问题,则必须直接使用 DOM 设置 src 属性:
constructor(private el: ElementRef) {}
...
public imageChanged(base64: string) {
const im: HTMLImageElement = this.el.nativeElement.querySelector('#imgid');
im.src = data;
}
这可能很难看,但速度很快。
我觉得这个帖子缺少具体的例子,这让我有些困难:
导入 DomSanitizer:
import { DomSanitizer } from '@angular/platform-browser';
在构造函数中定义:
constructor(private _sanitizer: DomSanitizer) { }
清理要作为图像源传递的 Base64 字符串(使用 trustResourceUrl):
this.imagePath = this._sanitizer.bypassSecurityTrustResourceUrl('data:image/jpg;base64,'
+ toReturnImage.base64string);
绑定到 html:
<img [src]="imagePath">
我想提出一个基于@gatapia 提供的解决方案的替代解决方案。
建议的解决方案是使用 @ViewChild 装饰器标记(请参阅此处的文档 https://angular.io/docs/ts/latest/api/core/index/ViewChild-decorator.html),以检索组件内的元素引用,并直接设置值,如下面的代码片段所示。需要注意的是,通过 ViewChild 引用的元素应该使用 # 绑定到局部变量,如下面的代码片段所示。
此外,正如 ElementRef 文档所解释的那样,直接使用 ElementRef 仍然存在 XSS 风险,在使用 DomSanitizer 时也存在这种风险。
@Component({
template: `
<div>
<img #imgRef> // Note that the #imgRef reference is required to be identified by Angular
</div>
`,
})
export class MyComponent implements OnInit {
src:string;
@ViewChild('imgRef') img:ElementRef;
constructor() {
// In your case, this will be resolved from the server
this.src = '';
}
ngOnInit() {
// Sets the value of the element
this.img.nativeElement.src = this.src;
}
}
以下 plunkr 提供了上面的工作代码片段 https://plnkr.co/edit/JXf25Pv8LqrFLhrw2Eum?p=preview
请在 Angular 2/4 中找到一个正确的示例,说明如何在 Base64 中上传图像及其显示。实际的 base64 字符串被转储到调试器控制台,当然可以存储在数据库等中。
import { Component, OnInit } from '@angular/core';
// Base 64 IMage display issues with unsafe image
import { DomSanitizer } from '@angular/platform-browser';
@Component({
selector: 'app-test',
template: `
<h1>Test 001 </h1>
<div class="form-group">
<label>Image</label>
<input type="file" class="form-control" accept="application/msword, application/vnd.ms-excel, application/vnd.ms-powerpoint,
text/plain, application/pdf, image/*" (change)="changeListener($event)">
</div>
<img *ngIf="base64Image" [src]="domSanitizer.bypassSecurityTrustUrl(base64Image)" />
`,
styleUrls: ['./test.component.css']
})
export class TestComponent implements OnInit {
private base64Image: string;
constructor(private domSanitizer: DomSanitizer) { }
ngOnInit() {
}
changeListener($event): void {
this.readThis($event.target);
}
readThis(inputValue: any): void {
var file: File = inputValue.files[0];
var myReader: FileReader = new FileReader();
myReader.onloadend = (e) => {
this.base64Image = myReader.result;
console.log(this.base64Image);
}
myReader.readAsDataURL(file);
}
}
解决方案:只需将 'data:image/jpg;base64'
用于您的图片标签,就像这样
<img src="{{'data:image/jpg;base64,' + imagePath}}" />
我正在尝试使用 angular 显示从远程服务器获取的图像 2.
在我的组件中,我有一个对象,它是一个 "university_info" 对象,它是我的模型。
export class myClass
{
university_info : university_info;
}
myFunction()
{
this.university_info = new university_info(responseFromServer[image])
}
export class university_info
{
imageBase64 : string
constructor(image : string)
{
this.imageBase64 = image
}
}
一切正常。我得到了 base64 图像,但是当我尝试以这种方式在 HTML 中显示它时:
<img [src]="'data:image/jpg;base64,'+university_info.imageBase64" />
这就是我得到的:
您可以尝试使用 _sanitizer.bypassSecurityTrustUrl
告诉 angular src
值是安全的。看看这个 class 来自 angular:
class DomSanitizationService {
sanitize(context: SecurityContext, value: any) : string
bypassSecurityTrustHtml(value: string) : SafeHtml
bypassSecurityTrustStyle(value: string) : SafeStyle
bypassSecurityTrustScript(value: string) : SafeScript
bypassSecurityTrustUrl(value: string) : SafeUrl
bypassSecurityTrustResourceUrl(value: string) : SafeResourceUrl
}
并以低安全为例 html:
export class AppComponent {
private _htmlProperty: string = '<input type="text" name="name">';
public get htmlProperty() : SafeHtml {
return this._sanitizer.bypassSecurityTrustHtml(this._htmlProperty);
}
constructor(private _sanitizer: DomSanitizationService){}
}
您必须确保 university_info.imageBase64
是 字符串类型 然后您的代码才能正常工作。
DEMO : http://plnkr.co/edit/pI35tx9gXZFO1sXj9Obm?p=preview
import {Component,ViewChild,Renderer,ElementRef,ContentChildren} from '@angular/core';
@Component({
selector: 'my-app',
template: `
<img [src]="'data:image/jpg;base64,'+imagePath"/>
`
})
export class App {
imagePath:string="iVBORw0KG...";
}
这个问题的 google 排名很高,所以我想我应该把我的发现放在这里。使用数据绑定设置图像的 [src]
属性 可能会出现问题,尤其是在某些较旧的移动设备上。因此,如果您在使用消毒剂+绑定方法时遇到性能问题,则必须直接使用 DOM 设置 src 属性:
constructor(private el: ElementRef) {}
...
public imageChanged(base64: string) {
const im: HTMLImageElement = this.el.nativeElement.querySelector('#imgid');
im.src = data;
}
这可能很难看,但速度很快。
我觉得这个帖子缺少具体的例子,这让我有些困难:
导入 DomSanitizer:
import { DomSanitizer } from '@angular/platform-browser';
在构造函数中定义:
constructor(private _sanitizer: DomSanitizer) { }
清理要作为图像源传递的 Base64 字符串(使用 trustResourceUrl):
this.imagePath = this._sanitizer.bypassSecurityTrustResourceUrl('data:image/jpg;base64,'
+ toReturnImage.base64string);
绑定到 html:
<img [src]="imagePath">
我想提出一个基于@gatapia 提供的解决方案的替代解决方案。
建议的解决方案是使用 @ViewChild 装饰器标记(请参阅此处的文档 https://angular.io/docs/ts/latest/api/core/index/ViewChild-decorator.html),以检索组件内的元素引用,并直接设置值,如下面的代码片段所示。需要注意的是,通过 ViewChild 引用的元素应该使用 # 绑定到局部变量,如下面的代码片段所示。
此外,正如 ElementRef 文档所解释的那样,直接使用 ElementRef 仍然存在 XSS 风险,在使用 DomSanitizer 时也存在这种风险。
@Component({
template: `
<div>
<img #imgRef> // Note that the #imgRef reference is required to be identified by Angular
</div>
`,
})
export class MyComponent implements OnInit {
src:string;
@ViewChild('imgRef') img:ElementRef;
constructor() {
// In your case, this will be resolved from the server
this.src = '';
}
ngOnInit() {
// Sets the value of the element
this.img.nativeElement.src = this.src;
}
}
以下 plunkr 提供了上面的工作代码片段 https://plnkr.co/edit/JXf25Pv8LqrFLhrw2Eum?p=preview
请在 Angular 2/4 中找到一个正确的示例,说明如何在 Base64 中上传图像及其显示。实际的 base64 字符串被转储到调试器控制台,当然可以存储在数据库等中。
import { Component, OnInit } from '@angular/core';
// Base 64 IMage display issues with unsafe image
import { DomSanitizer } from '@angular/platform-browser';
@Component({
selector: 'app-test',
template: `
<h1>Test 001 </h1>
<div class="form-group">
<label>Image</label>
<input type="file" class="form-control" accept="application/msword, application/vnd.ms-excel, application/vnd.ms-powerpoint,
text/plain, application/pdf, image/*" (change)="changeListener($event)">
</div>
<img *ngIf="base64Image" [src]="domSanitizer.bypassSecurityTrustUrl(base64Image)" />
`,
styleUrls: ['./test.component.css']
})
export class TestComponent implements OnInit {
private base64Image: string;
constructor(private domSanitizer: DomSanitizer) { }
ngOnInit() {
}
changeListener($event): void {
this.readThis($event.target);
}
readThis(inputValue: any): void {
var file: File = inputValue.files[0];
var myReader: FileReader = new FileReader();
myReader.onloadend = (e) => {
this.base64Image = myReader.result;
console.log(this.base64Image);
}
myReader.readAsDataURL(file);
}
}
解决方案:只需将 'data:image/jpg;base64'
用于您的图片标签,就像这样
<img src="{{'data:image/jpg;base64,' + imagePath}}" />