To jest mój kontroler.

ImagePath Czy ścieżka ma z bazy danych i {X1}} jest ścieżką magazynową Azure. I jocie do tych dwóch ścieżki i konwertujemy to w ciągu 64base. Ale jak przekazać, że wartość 64base resultimg do Base64string ponownie w powyższym validationdata? Ponieważ nie jestem w stanie uzyskać dostępu do obrazu bezpośrednio do wyświetlania. Tak wymagane do konwersji w 64azie.

Jak przejść resultimg Wartość do Base64string ???

[HttpGet]
public JsonResult GetImageList(int TaskID)
{
 try
 {
   List<Validation> validationdata = new List<Validation>();
   validationdata = (from d in _context.ImgTable
                where (d.Taskid == TaskID )
                select new Validation
                {
                    d.ImageID,
                    d.Taskid,
                    d.ImagePath,
                    blobUrl = blobContainer.Uri.AbsoluteUri,
                    Base64string  =???
                    
                }).ToList();
                
    //Joining two path and converting it to base64          
    List<string> ImgByteUrl = new List<string>();
    foreach (var item in validationdata.ToList())
    {
        var imgID = item.ID;
        var storagepath = item.blobUrl;         //azure storage url
        var imgurl = item.ImagePath.Trim();     // db image path
        var img1 = img.Split('\\');
        imgurl = (storagepath + '/' + img1[5]);  //joined both path

        byte[] bytes = (new FileUploadDownload(img)).GetByteStream();  //converting in byte
        string imreBase64Data = Convert.ToBase64String(bytes);
        string resultimg = string.Format("data:image/jpg;base64,{0}", imreBase64Data);
        ImgByteUrl.Add(resultimg);

        //validationdata.Add(resultimg);
    }
    
    var jsonResult = Json(validationdata, JsonRequestBehavior.AllowGet);
    jsonResult.MaxJsonLength = int.MaxValue;
    return jsonResult;
 }
 catch (Exception ex)
 {
 }

}

Pomóż, jak iść dalej indziej, kieruj mnie w inny sposób. Chcę wyświetlić obrazy na stronie HTML. Wybieram TaskID z Dropdownlist i kliknięcia wyświetlania powiązanych obrazów do tego zadowadki w HTML Table.Below jest funkcją JS:

$.ajax({
        type: 'GET',
        url: '@Url.Action("GetImageList")',
        datatype: JSON,
        data: {
                'TaskID': $("#tasklist").val()                //getting selected TaskID from dropdown
        },
        success: function (data) {
                 var row_no = 1;
                 $.each(data, function (i, item) {
            
                + "<td id='ItemId" + row_no + "' >" + item.ID + "</td>"               // displaying image id in html table

                "<td>"
                + "<div><object id='Image" + row_no + "' data=" + item.Base64string +></object>"  // display image for that imageid
                + "</div></td > "
     });

This is the image we get after converting to byte and passing that value to

Jest to obraz, który otrzymujemy po konwersji do bajtów i przekazywania tej wartości do html azure model-view-controller azure-webapps base64url

0
SDM 11 październik 2020, 17:12

1 odpowiedź

Najlepsza odpowiedź

Powinieneś użyć znacznika img.

enter image description here

enter image description here

Przykładowy kod:

<div>
    <img style='display:block; width:100px;height:100px;' id='base64image'                 
    src='' />
</div>

Twoja funkcja:

$.ajax({
    type: 'GET',
    url: '@Url.Action("GetImageList")',
    datatype: JSON,
    data: {
            'TaskID': $("#tasklist").val()                //getting selected TaskID from dropdown
    },
    success: function (data) {
             var row_no = 1;
             $.each(data, function (i, item) {
        
            + "<td id='ItemId" + row_no + "' >" + item.ID + "</td>"               // displaying image id in html table

            "<td>"
            + "<div><img id='Image" + row_no + "' src='.../> </div></td > "
 });
0
Jason Pan 12 październik 2020, 07:28