HTML.textBoxFor (x => x.Price, disabled = true) не публикует значение для действия поста контроллера! - PullRequest
1 голос
/ 18 июня 2011

Приложение Asp .net MVC 3 ... Это представление:

    Grupa: <%= Html.DropDownListFor(x => x.Grupa, Model.ListaGrupe) %> 
    Produsul: <%= Html.DropDownListFor(x => x.Produs, Model.ListaProduse) %> 
    Cantitate: <%=Html.TextBoxFor(x => x.Cantitate, new { style = "width: 100px;" })%>
    Pret: <%=Html.TextBoxFor(x => x.Pret, new { style = "width: 100px;", disabled = true})%>
    TVA: <%= Html.TextBoxFor(x => x.TVA, new { style = "width: 100px;", disabled = true })%>
    Valoare: <%= Html.TextBoxFor(x => x.NoTVA, new { style = "width: 120px;", disabled = true})%>
    Valoare cu TVA: <%=Html.TextBoxFor(x => x.Total, new { style = "width: 120px;", disabled = true})%>

Я использую некоторые JQuery для изменения Pret, TVA, NoTVA и Total на основе значений в Grupa, Produs и Cantitate.поэтому я не хочу, чтобы пользователь изменял значения внутри них.Вероятно, отключено = true не должно использоваться.Тогда как я могу сделать так, чтобы пользователь не мог изменять поля, кроме значения, которое будет отправлено в действие контроллера?

Ответы [ 3 ]

3 голосов
/ 18 июня 2011

Вы также можете сделать их доступными только для чтения, а не отключать их.С другой стороны, я думаю, что решение @Chris лучше, так что ваши измененные данные будут отправлены обратно.

1 голос
/ 18 июня 2011

Вы можете использовать Html.HiddenFor () и использовать вместо него <span> или <div>.Их значения будут опубликованы обратно.

0 голосов
/ 07 февраля 2013

Ну, это то, что я делал до сих пор,
мне не удалось создать хорошую, простую в использовании защиту только для чтения с использованием шифрования,
но мне удалось сделать что-то, что, я думаю, могло бы просто сделать.

как это работает:

  • Когда вы используете LockObject(o) объект, укажите свойства, определенные для ProtectedAttribute, определенные для.

  • добавить заблокированное значение в список, специально созданный для этого поля.
    ! список хранится в сеансе пользователя (на стороне сервера)

  • когда пользователь отправляет форму, IsValid проверяет, есть ли значение в списке заблокированных значений. если да, то все в порядке. в противном случае, это должно быть как-то изменено.

! количество значений не так велико и является временным для сеанса, но если это кого-то беспокоит, простой lockList.remove(node); может быть легко добавлен, когда значение проверено.
Примечание. Это может вызвать проблемы, когда пользователь использует кнопки «Назад» или повторно отправляет форму с помощью кнопки «Обновить».

сообщите мне, если вы обнаружите какие-либо проблемы, которые данная модель не учитывает ...
+ Выравнивание очень наивно, поэтому оно работает только с типами значений для времени.


Код:

Создан атрибут с именем ProtectedAttribute:

[AttributeUsage(AttributeTargets.Property, AllowMultiple = true, Inherited = false)]
public class ProtectedPropertyAttribute : ValidationAttribute
{
    private static Dictionary<string, LinkedList<object>> savedValues;
    static ProtectedPropertyAttribute()
    {
        savedValues = (Dictionary<string, LinkedList<object>>)HttpContext.Current.Session["ProtectedAttributeData"];
        if (savedValues != null) 
            return;
        savedValues = new Dictionary<string, LinkedList<object>>();
        HttpContext.Current.Session.Add("ProtectedAttributeData", savedValues);
    }

    public static void LockObject(object obj)
    {
        Type type = obj.GetType();
        foreach (PropertyInfo property in type.GetProperties())
        {
            LockProperty(obj, property);
        }
    }

    public static void LockProperty(object obj, PropertyInfo property)
    {
        ProtectedPropertyAttribute protectedAttribute =
            (ProtectedPropertyAttribute)
            property.GetCustomAttributes(typeof (ProtectedPropertyAttribute), false).FirstOrDefault();
        if (protectedAttribute == null)
            return;
        if(protectedAttribute.Identifier == null)
            protectedAttribute.Identifier = property.Name;

        LinkedList<object> list;
        if (!savedValues.TryGetValue(protectedAttribute.Identifier, out list))
        {
            list = new LinkedList<object>();
            savedValues.Add(protectedAttribute.Identifier, list);
        }
        list.AddLast(property.GetValue(obj, null));
    }

    public string Identifier { get; set; }

    public ProtectedPropertyAttribute()
    {
    }

    public ProtectedPropertyAttribute(string errorMessage) : base(errorMessage)
    {
    }

    public ProtectedPropertyAttribute(Func<string> errorMessageAccessor) : base(errorMessageAccessor)
    {
    }

    protected override ValidationResult IsValid (object value, ValidationContext validationContext)
    {
        LinkedList<object> lockedValues;

        if (Identifier == null)
            Identifier = validationContext.DisplayName;

        if (!savedValues.TryGetValue(Identifier, out lockedValues))
            return new ValidationResult(FormatErrorMessage(validationContext.MemberName), new[] { validationContext.MemberName });

        bool found = false;
        LinkedListNode<object> node = lockedValues.First;
        while (node != null)
        {
            if(node.Value.Equals(value))
            {
                found = true;
                break;
            }
            node = node.Next;
        }

        if(!found)
            return new ValidationResult(FormatErrorMessage(validationContext.MemberName), new[] { validationContext.MemberName });

        return ValidationResult.Success;
    }
}

Поместите этот атрибут в любое свойство вашей модели так же, как и в любую другую проверку.

public class TestViewModel : Controller
{
    [ProtectedProperty("You changed me. you bitch!")]
    public string DontChangeMe { get; set; }

    public string ChangeMe { get; set; }
}

в контроллере, после того как вы закончите с объектом viewmodel, Вы звоните ProtectedAttribute.LockObject(myViewModel)

public class TestController : Controller
{
    public ActionResult Index()
    {
        TestViewModel vm = new TestViewModel {ChangeMe = "a1", DontChangeMe = "b1"};
        ProtectedPropertyAttribute.LockObject(vm);
        return View(vm);
    }


    public string Submit(TestViewModel vm)
    {
        string errMessage;
        return !validate(out errMessage) ? "you are a baaad, man." + errMessage : "you are o.k";
    }

    private bool validate(out string errormessage)
    {
        if (ModelState.IsValid)
        {
            errormessage = null;
            return true;
        }

        StringBuilder sb = new StringBuilder();
        foreach (KeyValuePair<string, ModelState> pair in ModelState)
        {
            sb.Append(pair.Key);
            sb.Append(" : <br/>");

            foreach (ModelError err in pair.Value.Errors)
            {
                sb.Append(" - ");
                sb.Append(err.ErrorMessage);
                sb.Append("<br/>");
            }

            sb.Append("<br/>");
        }
        errormessage = sb.ToString();
        return false;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...