How would you implement database updates via email?

前端 未结 6 533
萌比男神i
萌比男神i 2021-02-04 22:11

I\'m building a public website which has its own domain name with pop/smtp mail services. I\'m considering giving users the option to update their data via email - something sim

相关标签:
6条回答
  • 2021-02-04 22:23

    E-mails can be trivially forged. I would only do this if you can process PGP / SMime certificates in your application.

    Other than that, I see no reason why not!

    0 讨论(0)
  • 2021-02-04 22:24

    use a dotnet popclient to read the incoming emails, parse them for whatever you are expecting and insert the data into the database.

    see codeproject website for simple popclient implementation you would have to decided on the email content yourself, eg data only, payload of sql statements, etc

    0 讨论(0)
  • 2021-02-04 22:28

    I have done something similar, using Lumisoft's IMAP client and scheduling a task in my app that checks every x minutes the configured mail address for updates. For scheduling I recommend quartz.net. No launching external processes or anything.

    0 讨论(0)
  • 2021-02-04 22:33

    If the data is somewhat "critical", or at least moderately important, do NOT use their username as the "change-data-address". Example: You might be tempted to create an address like username@domain.com, but instead use username-randomnumer@domain.com where you give them the random number if the visit the web-page. That way people can not update other peoples data just by knowing their username.

    0 讨论(0)
  • 2021-02-04 22:34

    For starters you need to have hosting that allows you to create a catch-all mailbox.

    Secondly you need a good POP3 or IMAP library, which is not included AFAIK in the .NET stack.

    Then you would write a Command Line application or a Service that regularly checks the mailbox, pulls messages, inserts content in db based on the "To" address (which is unique for each user), and then deletes the email from the mailbox.

    It's feasible and sounds like fun. Just make sure you have all you need before you start!

    0 讨论(0)
  • 2021-02-04 22:39

    You could also identify the user based on sender address. This is how Tripit (and probably others) does it. This only requires one e-mail address on your end.

    0 讨论(0)
提交回复
热议问题