Более элегантный способ будет использовать регулярное выражение (regex) следующим образом:
public class DecimalDigitsInputFilter implements InputFilter {
Pattern mPattern;
public DecimalDigitsInputFilter(int digitsBeforeZero,int digitsAfterZero) {
mPattern=Pattern.compile("[0-9]{0," + (digitsBeforeZero-1) + "}+((\\.[0-9]{0," + (digitsAfterZero-1) + "})?)||(\\.)?");
}
@Override
public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {
Matcher matcher=mPattern.matcher(dest);
if(!matcher.matches())
return "";
return null;
}
}
Чтобы использовать его:
editText.setFilters(new InputFilter[] {new DecimalDigitsInputFilter(5,2)});
Можно создать собственное, авторизовывают атрибут как это:
public class ClubAuthorizeAttribute : AuthorizeAttribute
{
public override void OnAuthorization(AuthorizationContext filterContext)
{
base.OnAuthorization(filterContext);
if (filterContext.Cancel && filterContext.Result is HttpUnauthorizedResult)
{
filterContext.Result = new RedirectToRouteResult(
new RouteValueDictionary {
{ "clubShortName", filterContext.RouteData.Values[ "clubShortName" ] },
{ "controller", "Account" },
{ "action", "Login" },
{ "ReturnUrl", filterContext.HttpContext.Request.RawUrl }
});
}
}
}
я использовал это для перенаправления в определенный клуб в сайте членства в клубе, который я создаю. Вы могли адаптировать это к своей потребности. BTW, в моем случае, который я действительно перенаправляю к странице входа в систему, но я проверяю, чтобы видеть, авторизовывается ли пользователь и если так, отображают сообщение, что у них нет корректных полномочий. Несомненно Вы могли также добавить что-то к ViewData или TempData для отображения на странице, но я не попробовал это
РЕДАКТИРОВАНИЕ AuthorizationContext. Отмена больше не существует в RC. "filterContext. Результатом является HttpUnauthorizedResult", кажется, достаточно: , Что произошло с filterContext. Отмена (ASP.NET MVC)