- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 TinyMCE 插件,用于使用表单上传图像。这种形式在 FF 和 Chrome 中完美运行,但在 IE8+ 中中断。我已确保对 NETWORK SERVICE 等有适当的权限。
这里是错误:
Could not find a part of the path 'C:\Users\XXXX\Desktop\image.jpg'.
ASPX:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="imgmanager.aspx.cs" Inherits="TinyMCE.NET.tiny_mce.plugins.aspnetbrowser.imgmanager"
EnableEventValidation="false" %>
<!DOCTYPE html>
<head runat="server">
<title></title>
<link href="css/aspnetbrowser.css" rel="stylesheet" type="text/css" />
<script src="../../tiny_mce.js" type="text/javascript"></script>
<script src="../../tiny_mce_popup.js" type="text/javascript"></script>
<script src="js/aspnetbrowser.js" type="text/javascript"></script>
</head>
<body>
<form id="form1" runat="server" action="#">
<asp:ScriptManager ID="ImageManagerScriptManager" runat="server">
</asp:ScriptManager>
<table style="width:100%;">
<tr>
<td colspan="3">
<asp:Literal ID="ErrorLiteral" runat="server" Text="" />
</td>
</tr>
<tr style="display:none;">
<td>
<asp:Literal ID="PathSelectLiteral" runat="server" Text="Select Location" />
</td>
<td>
<asp:UpdatePanel ID="PathDropDownUpdatePanel" runat="server">
<ContentTemplate>
<asp:DropDownList ID="PathDropDown" runat="server" AppendDataBoundItems="true" AutoPostBack="true"
OnSelectedIndexChanged="PathDropDown_SelectedIndexChanged">
<asp:ListItem Text="--Root--" Value="-1" />
</asp:DropDownList>
</ContentTemplate>
</asp:UpdatePanel>
</td>
<td>
<!--<asp:Button ID="DeleteFolderButton" runat="server" Text="Delete" OnClick="DeleteFolderButton_Click"
OnClientClick="javascript:return confirm('do you wish to delete this directory?');" />-->
</td>
</tr>
<!--tr>
<td>
<asp:Literal ID="FolderLiteral" runat="server" Text="Create Folder:" />
</td>
<td>
<asp:TextBox ID="FolderTextBox" runat="server" />
</td>
<td>
<asp:Button ID="CreateFolderButton" runat="server" Text="Create" OnClick="CreateFolderButton_Click" />
</td>
</tr-->
<tr>
<td>
<asp:Literal ID="SelectImageLiteral" runat="server" Text="Select Image:" />
</td>
<td>
<asp:FileUpload ID="ImageFileUpload" runat="server" />
<asp:RegularExpressionValidator ID="ImageFileUploadRegExValidator" runat="server"
ControlToValidate ="ImageFileUpload" ValidationExpression=".*((\.jpg)|(\.bmp)|(\.gif)|(\.png))"
ErrorMessage="only jpg, bmp, gif and png files are allowed" Text="*" />
</td>
<td>
<asp:Button ID="UploadButton" runat="server" Text="Upload" OnClick="UploadButton_Click" />
</td>
</tr>
<tr>
<td colspan="3">
<asp:Literal ID="AvailableImagesLiteral" runat="server" Text="Available Images:" />
</td>
</tr>
<tr>
<td colspan="3">
<asp:UpdatePanel ID="ImageGridViewUpdatePanel" runat="server">
<Triggers>
<asp:AsyncPostBackTrigger ControlID="PathDropDown" />
</Triggers>
<ContentTemplate>
<asp:GridView ID="ImageGridView" runat="server" DataKeyNames="Name" AllowPaging="true"
AutoGenerateColumns="false" EnableViewState="false" OnRowDataBound="imageGridView_RowDataBound"
PageSize="5" OnSelectedIndexChanged="ImageGridView_SelectedIndexChanged" OnPageIndexChanging="ImageGridView_PageIndexChanging"
OnRowCommand="ImageGridView_RowCommand" OnRowDeleting="ImageGridView_RowDeleting">
<EmptyDataTemplate>
No Images Found!
</EmptyDataTemplate>
<Columns>
<asp:TemplateField>
<ItemTemplate>
<asp:Button ID="DeleteButton" CommandName="Delete" Text="X" Width="21" Height="21"
ToolTip="delete current image." runat="server" OnClientClick="javascript:return confirm('do you wish to delete this image?');" />
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField>
<ItemTemplate>
<asp:Literal ID="radiobuttonMarkup" runat="server" />
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="Images">
<ItemTemplate>
<asp:Image ID="displayImage" runat="server" style="max-width:200px;" />
</ItemTemplate>
</asp:TemplateField>
</Columns>
<SelectedRowStyle BackColor="#cacaca" />
</asp:GridView>
</ContentTemplate>
</asp:UpdatePanel>
</td>
</tr>
<tr>
<td>
<asp:UpdatePanel ID="SelectButtonUpdatePanel" runat="server">
<Triggers>
<asp:AsyncPostBackTrigger ControlID="ImageGridView" />
</Triggers>
<ContentTemplate>
<asp:Button ID="SelectButton" runat="server" CausesValidation="false" Text="Select"
OnClientClick="AspNetBrowserDialog.insert(,);return false;" />
</ContentTemplate>
</asp:UpdatePanel>
</td>
<td>
<asp:Button ID="CancelButton" runat="server" CausesValidation="false" Text="Cancel"
OnClientClick="tinyMCEPopup.close();" />
</td>
</tr>
</table>
<asp:ValidationSummary ID="ValidationSummary1" runat="server" />
</form>
</body>
</html>
代码隐藏:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.IO;
using System.Web.UI.HtmlControls;
using System.Collections;
namespace TinyMCE.NET.tiny_mce.plugins.aspnetbrowser
{
public partial class imgmanager : System.Web.UI.Page
{
#region variables
public string host = string.Empty;
private const string checkedAttributeHTML = "checked=\"checked\"";
//HACK: the javascript this.style.visibility='hidden'; is a terrible hack to prevent the client doubleclick crash.
private const string radiobuttonHTML = "<input type=\"radio\" name=\"imagegroup\" id=\"selected{0}\" value=\"{0}\" onclick=\"{1};this.style.visibility='hidden';\" {2} />";
public const string thispage = "imgmanager.aspx";
public string defaultUploadPath = "~/nForum/uploads/";
public string aspnetimagebrowserImagePath = string.Empty;
public string physicalPath = string.Empty;
public string uploadPath = string.Empty;
private const string onDeleteError = "File could not be deleted!";
private const string onFileExistError = "File already exists!";
private const string onFolderExistError = "Folder already exists!";
private const string onNoFileSelectedError = "No image file was selected!";
private const string onFileSaveSuccess = "File was uploaded successfully!";
private string currentUrl = string.Empty;
public string aspnetVirtualFolderPath = string.Empty;
private HttpContext context = null;
private FileInfo[] imagefiles = new FileInfo[] { };
#endregion
#region properties
private int CurrentIndex
{
get { return (int?) ViewState["CurrentIndex"] ?? -1; }
set { ViewState["CurrentIndex"] = value; }
}
#endregion
protected void Page_Load(object sender, EventArgs e)
{
context = HttpContext.Current;
currentUrl = context.Request.Url.AbsoluteUri;
host = context.Request.ServerVariables["HTTP_HOST"];
if (context.Request.IsSecureConnection)
{
host = host.Replace("http:/", "https:/");
}
physicalPath = context.Server.MapPath("~");
uploadPath = context.Server.MapPath(Path.Combine(physicalPath, defaultUploadPath));
aspnetVirtualFolderPath = ToVirtualPath(context.Request.Path.Replace(thispage, string.Empty));
if (!Page.IsPostBack)
{
SelectButton.Enabled = false;
BindDirectoryDropDown();
}
BindData();
}
#region binding
private void BindDirectoryDropDown()
{
try
{
PathDropDown.Items.Clear();
PathDropDown.Items.Add(new ListItem("/images/", uploadPath));
RecursiveSearch(uploadPath, PathDropDown);
}
catch (UnauthorizedAccessException ex)
{
ErrorLiteral.Text = "UnauthorizedAccessException\n" + ex.Message;
}
}
private DirectoryInfo dirInfo;
private string parent = string.Empty;
private void RecursiveSearch(string path, DropDownList dropdown)
{
if (!Directory.Exists(path))
return;
dirInfo = new DirectoryInfo(path);
foreach (FileSystemInfo fileInfo in dirInfo.GetDirectories())
{
if (fileInfo.Attributes == FileAttributes.Directory)
{
parent += "/" + Directory.GetParent(fileInfo.FullName).Name;
ListItem li = new ListItem(parent + "/" + fileInfo.Name, fileInfo.FullName);
dropdown.Items.Add(li);
RecursiveSearch(fileInfo.FullName, dropdown);
}
}
parent = string.Empty;
}
#endregion
protected void PathDropDown_SelectedIndexChanged(object sender, EventArgs e)
{
SelectButton.Enabled = false;
BindData();
}
#region binding
private void BindData()
{
if (Directory.Exists(PathDropDown.SelectedValue))
{
DirectoryInfo info = new DirectoryInfo(PathDropDown.SelectedValue);
LoadFiles(info);
}
}
private void LoadFiles(DirectoryInfo info)
{
var files = info.GetFiles();
if (files != null)
{
imagefiles = files;
foreach (var item in files)
{
ImageGridView.DataSource = files;
ImageGridView.DataBind();
}
}
}
#endregion
#region IO utilities
private void DeleteFile(string file)
{
if (!string.IsNullOrEmpty(file) && File.Exists(file))
{
try
{
File.Delete(file);
}
catch (Exception ex)
{
ErrorLiteral.Text = ex.Message;
}
}
}
private void DeleteFolder(string folder)
{
if (!string.IsNullOrEmpty(folder) && Directory.Exists(folder))
{
try
{
Directory.Delete(folder);
}
catch (Exception ex)
{
ErrorLiteral.Text = ex.Message;
}
}
}
private void CreateFolder(string folder)
{
if (!string.IsNullOrEmpty(folder) && !Directory.Exists(folder))
{
try
{
Directory.CreateDirectory(folder);
BindDirectoryDropDown();
}
catch (Exception ex)
{
ErrorLiteral.Text = ex.Message;
}
}
}
private void CreateFile(string file)
{
if (!string.IsNullOrEmpty(file) && !File.Exists(file))
{
try
{
File.Delete(file);
}
catch (Exception ex)
{
ErrorLiteral.Text = ex.Message;
}
}
}
#endregion
#region create/delete directory
protected void CreateFolderButton_Click(object sender, EventArgs e)
{
string folder = FolderTextBox.Text.Trim();
if (!string.IsNullOrEmpty(folder))
{
string folderPath = Path.Combine(PathDropDown.SelectedValue, folder);
CreateFolder(folderPath);
FolderTextBox.Text = "";
}
}
protected void DeleteFolderButton_Click(object sender, EventArgs e)
{
string directory = PathDropDown.SelectedValue;
if (!string.IsNullOrEmpty(directory) && Directory.Exists(directory))
{
try
{
Directory.Delete(directory);
this.BindDirectoryDropDown();
this.BindData();
}
catch (IOException ex)
{
ErrorLiteral.Text = ex.Message;
}
}
}
#endregion
#region upload file
protected void UploadButton_Click(object sender, EventArgs e)
{
if (ImageFileUpload.HasFile)
{
try
{
if (Directory.Exists(PathDropDown.SelectedValue))
{
HttpPostedFile postedFile = ImageFileUpload.PostedFile;
postedFile.SaveAs(Path.Combine(PathDropDown.SelectedValue, postedFile.FileName));
ErrorLiteral.Text = onFileSaveSuccess;
context.Response.Redirect(currentUrl);
}
}
catch (Exception ex)
{
ErrorLiteral.Text = ex.Message;
}
}
else
{
ErrorLiteral.Text = onNoFileSelectedError;
}
}
#endregion
#region gridview methods
protected void ImageGridView_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
}
protected void ImageGridView_RowCommand(object sender, GridViewCommandEventArgs e)
{
if (e.CommandName.Equals("Delete"))
{
var file = imagefiles[Convert.ToInt32(e.CommandArgument)];
if (file != null)
{
DeleteFile(file.FullName);
BindData();
}
}
}
protected void ImageGridView_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
ImageGridView.PageIndex = e.NewPageIndex;
BindData();
}
protected void imageGridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.DataRow)
{
GridViewRow row = (GridViewRow)e.Row;
FileInfo fi = (FileInfo)row.DataItem;
Image imageList = e.Row.FindControl("displayImage") as Image;
if (imageList != null)
{
imageList.ImageUrl = ToVirtualPath(fi, false);
}
Button deleteButton = e.Row.FindControl("DeleteButton") as Button;
if (deleteButton != null)
{
deleteButton.CommandArgument = Convert.ToString(row.RowIndex);
}
}
}
protected void ImageGridView_SelectedIndexChanged(object sender, EventArgs e)
{
if (ImageGridView.SelectedIndex > -1)
{
GridViewRow row = ImageGridView.SelectedRow;
if (row != null)
{
var file = imagefiles[ImageGridView.SelectedIndex];
string script = "AspNetBrowserDialog.insert('{0}','{1}');return false;";
script = string.Format(script, ToVirtualPath(file, true), file.Name);
SelectButton.Enabled = true;
SelectButton.OnClientClick = script;
CurrentIndex = row.RowIndex;
}
}
else
{
SelectButton.Enabled = false;
}
}
#endregion
#region path utilities
private string ToVirtualPath(FileInfo fi, bool forTinyMCE = false)
{
string root = context.Server.MapPath("~/");
string path = (fi.Directory.FullName + "\\" + fi.Name);
path = path.Replace(root, string.Empty);
path = path.Replace("\\", "/");
if (forTinyMCE)
return ("/" + path);
else
return ("~/" + path);
}
private string ToVirtualPath(string filename)
{
string root = context.Server.MapPath("~/");
string path = filename;
path = path.Replace(root, string.Empty);
path = path.Replace("\\", "/");
return ("~/" + path);
}
#endregion
#region render
protected override void Render(HtmlTextWriter writer)
{
foreach(GridViewRow row in ImageGridView.Rows)
{
if (row.RowType == DataControlRowType.DataRow)
{
Literal radiobuttonMarkup = row.FindControl("radiobuttonMarkup") as Literal;
if (radiobuttonMarkup != null)
{
string script = ClientScript.GetPostBackEventReference(ImageGridView, "Select$" + row.RowIndex, true);
string attr = string.Empty;
if (CurrentIndex == row.RowIndex)
attr = checkedAttributeHTML;
radiobuttonMarkup.Text = string.Format(radiobuttonHTML, row.RowIndex, script, attr);
}
}
}
base.Render(writer);
}
#endregion
}
}
最佳答案
通过更改修复:
HttpPostedFile postedFile = ImageFileUpload.PostedFile;
postedFile.SaveAs(Path.Combine(PathDropDown.SelectedValue, postedFile.FileName));
到:
string filename = Path.GetFileName(ImageFileUpload.FileName);
ImageFileUpload.SaveAs(Server.MapPath("~/nForum/uploads/") + filename);
关于c# - 找不到路径的一部分 - ASP.net/C# 图片上传,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31537799/
我想使用 Angular.js 转换从服务器获取的图像数据(用于 ionic 框架),我使用了这段代码: $http.post(link, { token: token,
我正在为我的应用制作一个登陆页面。如果它们在 iOS 设备上,我希望它只显示“App Store”图标,但在 Android 上隐藏它。如果它们在 Android 设备上,则只有“Play Store
如何在同一页面上多次显示同一张图片? function xdf(){ for (i=0;ihello world'); } } 此代码显示“hello world”10 次。我想要同样的东西,
您好,我有一个 1px 的 png 文件,我试图将其设置为两个水平相邻的 div 的背景图像。html 和 css 如下:- hi hello css是这样的 div { width: 50%
我的 PHP 项目安装了 Prestashop 1.4.9.0。当我添加一个新产品时,我上传了一个PNG格式的图片,但是当它在客户端显示时,图片是JPG格式的。 如何保留图片扩展名? 最佳答案 在后台
我用 http://www.regexper.com查看一个象形表示正则表达式很多。我想要一种理想的方法: 向站点发送正则表达式 打开显示该表达式的站点 例如,让我们使用正则表达式:"\\s*foo[
我不知道为什么在 MAC OS X (Mail 6.2) 的邮件客户端中图像显示如下: 和其他邮件客户端,如 gmail、outlook 或 private,图像是正确的,看起来像这样: PHP邮件程
我正在使用此处找到的示例。 Mozilla developers 我对这个例子很感兴趣。 function upload(postUrl, fieldName, filePath) { var f
我不知道为什么在 MAC OS X (Mail 6.2) 的邮件客户端中图像显示如下: 和其他邮件客户端,如 gmail、outlook 或 private,图像是正确的,看起来像这样: PHP邮件程
我的问题是如何根据用户在javafx中选择的复选框和/或单选按钮生成带有汽车图片设置的按钮? 我正在用汽车图片模拟汽车经销商网站。用户应该能够通过单击复选框和/或单选按钮选择来过滤显示的图片。 我首先
我正在开发Java客户端,它应该支持多种语言。为了翻译文本,我使用 Java ResourceBoundle,它工作正常。 现在问题出在图像上。客户端应加载大约 50 张图像,这些图像是棋盘游戏的特定
我对 jQuery 还很陌生,但我正在寻找一个简单的脚本,通过淡入和淡出的方式在标题中循环 3 或 4 个背景图像。它们是透明的 png,因此我尝试过的许多 slider 都不起作用。 有什么想法吗?
我有一个 HTML 文档,其中包含本地文件的图像,例如: ios - 物理主体大于它分配给的纹理(图片)
我的 Sprite “physicsBody ”属性之一出现问题。 我已经放置了physicsBody节点“barn ”,直接位于 non-physicsBody 之上节点“mound”没有任何问题。
我想剪切图片的特定部分并用它来将剪切的图像与存储在 HDD 中的另一个图像进行比较。问题是我不知道如何获取源图像的特定部分。我知道要裁剪的图像的位置 (X,Y)。 最佳答案 这将加载原始版本并创建
如何使用裁剪实用程序在 javascript 中实现图像 uploader 。你如何通过 AJAX 提交图像文件?解决方案是否跨域兼容? 最佳答案 要实现具有裁剪功能的图片上传小部件,您必须: 将图像
public void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityRes
我想在我的 android 应用程序中显示一个国家的图片。国家必须按地区划分。因此,当用户单击特定区域时,应打开特定屏幕。区域也应该用线分隔,以便用户可以看到区域的开始/结束位置。 这是一个国家的例子
首先我想对这个问题表示歉意,因为我知道已经有很多人问过这个问题了。但我搜索的所有答案都没有解决我的问题。所以希望您考虑这个问题并帮助我解决这个问题。 所以基本上我正在尝试上传图像文件,当我提交它时,会
我几乎有了想要的数据...但需要帮助过滤它。 (图在底部) 下面的查询返回状态为 Member-id5 的所有记录,但我需要对其进行过滤。例如:如果我对等做了一个简单的查询。 (exp_channel
我是一名优秀的程序员,十分优秀!