问题描述
我有一个简单的表单,包含三个字段,单击提交,我在控制器中接收到数据,我尝试使用该数据实例化一个对象,然后通过存储库将其添加到我的数据库中,但是当我单击提交后,我收到一个错误,您将在最后看到
所以这是我的控制器方法:(我根据此处的答案添加了int.TryParse方法,希望这是我的问题,但没有解决)
[HttpPost]
public IActionResult insertBook(string bookName,string bookPrice,string categoryId)
{
Category category = _categoryRepository.getCategoryById(Int32.Parse(categoryId));
int val = 0;
bool result = int.TryParse(categoryId,out val);
Book book = result ? new Book(
10,bookName,Double.Parse(bookPrice),"https://i.stack.imgur.com/IyQzE.png?s=128&g=1&g&s=32",val
) : new Book(
10,3 // default category is with id 3
);
_bookRepository.insertBook(book);
return RedirectToAction("Index","Home");
}
public class Book
{
[Key]
public int BookId { get; set; }
public string BookName { get; set; }
public double BookPrice { get; set; }
public string BookImageUrl { get; set; }
[ForeignKey("Category")]
public int CategoryId { get; set; }
public Category Category { get; set; }
public Book(int bookId,string bookName,double bookPrice,string bookImageUrl,int categoryId){
BookId = bookId;
BookName = bookName;
BookPrice = bookPrice;
BookImageUrl = bookImageUrl;
CategoryId = categoryId;
}
}
这是我得到的错误:
System.FormatException: 'Input string was not in a correct format.'
例如,当我检查从表单获取的数据时,我看到它的格式正确,这意味着我在期待(因此Int32.parse应该可以在这里使用),以及 为什么要预订是NULL吗?
有什么想法吗?
任何帮助将不胜感激。
解决方法
最可能由于Double.Parse(bookPrice)
而导致格式异常。尝试使用不变文化,例如:
Convert.ToDouble(bookPrice,CultureInfo.InvariantCulture);
只需确保,您还可以使用以下方法:
double parsedBookPrice;
var isValidDouble = Double.TryParse(bookPrice,out parsedBookPrice);
如果isValidDouble
为假,则45.00
格式对于您的服务器区域性很可能无效。