MVC 3 Uploadify HTTP 302 ошибка - PullRequest
       16

MVC 3 Uploadify HTTP 302 ошибка

0 голосов
/ 21 января 2012

У меня проблемы с конфигурацией uploadify (v.2.1.4) и моим проектом MVC 3. Вот код, который возвращает код HTTP 302.

        @{string auth = @Request.Cookies[FormsAuthentication.FormsCookieName] == null ? string.Empty : Request.Cookies[FormsAuthentication.FormsCookieName].Value;}

        $("#fileuploader").uploadify({
            uploader: '@Url.Content("~/Scripts/uploadify.swf")',
            script: '@Url.Action("Upload", "Control")',
            scriptData: { token: "@auth" },
            fileDataName: 'file',
            buttonText: 'Upload file',
            multi: false,
            sizeLimit: 22222222222,
            simUploadLimit: 1,
            cancelImg: '@Url.Content("~/Images/uploadify-cancel.png")',
            auto: true,
            onError: function(event, queueID, fileObj, errorObj) {
                alert("Error!!! Type: [" + errorObj.type + "] Info [" + errorObj.info + "]");
            },
            onComplete: function (event, queueId, fileObj, response, data) {
                alert(response);
            }
        });

public class ControlController : Controller
{        
    [HttpPost]        
    public ActionResult Upload(string token, HttpPostedFileBase file)
    {
        if (file != null && file.ContentLength > 0)
        {
            var appData = Server.MapPath("~/app_data");
            var filename = Path.Combine(appData, Path.GetFileName(file.FileName));
            file.SaveAs(filename);
        }
        return Json(true);
    }
}

1) Действие контроллера не запускается

2) Я нашел эту тему Получение Uploadify для работы с asp.net-mvc , но если я использую этот атрибут для моего контроллера, я вижу, что "AuthenticationToken" равно нулю (я вошел в систему)

3) Если я установлю опцию загрузки method на post, я получу #2032 error

EDIT

Контроллер является контроллером Admininistration, поэтому я использую этот атрибут для него:

    protected override bool AuthorizeCore(HttpContextBase httpContext) {

        if (!HttpContext.Current.User.Identity.IsAuthenticated)
            return false;

        if (admin && !um.IsAdmin(HttpContext.Current.User.Identity.Name))
            return false;

        return true;
    } 

, который возвращает истину. Я заметил, что если я удалю этот атрибут, загрузка начнет работать. Но мне нужен этот атрибут

1 Ответ

1 голос
/ 01 февраля 2012
it's help you.
var auth = "@(Request.Cookies[FormsAuthentication.FormsCookieName]==null ? string.Empty : Request.Cookies[FormsAuthentication.FormsCookieName].Value)";
    var ASPSESSID = "@(Session.SessionID)";

    $("#uploadifyLogo").uploadify({
        ...
        'scriptData': { 'ASPSESSID': ASPSESSID, 'AUTHID': auth  }
    });

В Global.asax:

protected void Application_BeginRequest(object sender, EventArgs e)
    {
      /* we guess at this point session is not already retrieved by application so we recreate cookie with the session id... */
        try
        {
            string session_param_name = "ASPSESSID";
            string session_cookie_name = "ASP.NET_SessionId";

            if (HttpContext.Current.Request.Form[session_param_name] != null)
            {
                UpdateCookie(session_cookie_name, HttpContext.Current.Request.Form[session_param_name]);
            }
            else if (HttpContext.Current.Request.QueryString[session_param_name] != null)
            {
                UpdateCookie(session_cookie_name, HttpContext.Current.Request.QueryString[session_param_name]);
            }
        }
        catch
        {
        }

        try
        {
            string auth_param_name = "AUTHID";
            string auth_cookie_name = FormsAuthentication.FormsCookieName;

            if (HttpContext.Current.Request.Form[auth_param_name] != null)
            {
                UpdateCookie(auth_cookie_name, HttpContext.Current.Request.Form[auth_param_name]);
            }
            else if (HttpContext.Current.Request.QueryString[auth_param_name] != null)
            {
                UpdateCookie(auth_cookie_name, HttpContext.Current.Request.QueryString[auth_param_name]);
            }

        }
        catch
        {
        }
    }

    private void UpdateCookie(string cookie_name, string cookie_value)
    {
        HttpCookie cookie = HttpContext.Current.Request.Cookies.Get(cookie_name);
        if (null == cookie)
        {
            cookie = new HttpCookie(cookie_name);
        }
        cookie.Value = cookie_value;
        HttpContext.Current.Request.Cookies.Set(cookie);
    }
...