みなさんこんにちは!
ひろぽんです!
最近はC#のWebフレームワークのASP.NETが楽しいなーと思って、日々様々な勉強をしています!
今回はそんな中から、ASP.NETでログインしているユーザーの情報のみやり取りする流れを書いていきたいと思います!
ただ一気に全部書くと長くなってしまいそうなので、今回は下記の構成に分けて記事を書いていこうと思います!
- 概要【この記事】
- スキャフォールドで作成したControllerのINDEXメソッド
- スキャフォールドで作成したControllerのDetailsメソッド
- スキャフォールドで作成したControllerのCreateメソッド
目次
前提となるModelの構造
TodoMODELの構造
    public class Todo
    {
        public int Id { get; set; }
        public string Sammary { get; set; }
        public string Detail { get; set; }
        public DateTime Limit { get; set; }
        public bool Done { get; set; }
        public virtual User User { get; set; }
    }TodoModelには、IDがあります。
また概要と詳細があり、期限と完了フラグがあります。
UserModelの構造
    public class User
    {
        public int id { get; set; }
        public string UserName { get; set; }
        public string Password { get; set; }
        public virtual ICollection<Todo> todoes { get; set; }
    }こちらもシンプルにUserIDとNameとPassword。そして、Todoを複数持っているといった感じですね。
スキャフォールドしてみる
上記のUserModelとTodoModelをスキャフォールドすると下記のようなControllerが作られます。
TodoのController
    public class TodoesController : Controller
    {
        private AspStudyContext db = new AspStudyContext();
        // GET: Todoes
        public ActionResult Index()
        {
            return View(db.Todoes.ToList());
        }
        // GET: Todoes/Details/5
        public ActionResult Details(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Todo todo = db.Todoes.Find(id);
            if (todo == null)
            {
                return HttpNotFound();
            }
            return View(todo);
        }
        // GET: Todoes/Create
        public ActionResult Create()
        {
            return View();
        }
        // POST: Todoes/Create
        // 過多ポスティング攻撃を防止するには、バインド先とする特定のプロパティを有効にしてください。
        // 詳細については、https://go.microsoft.com/fwlink/?LinkId=317598 を参照してください。
        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Create([Bind(Include = "Id,Sammary,Detail,Limit,Done")] Todo todo)
        {
            if (ModelState.IsValid)
            {
                db.Todoes.Add(todo);
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(todo);
        }
        // GET: Todoes/Edit/5
        public ActionResult Edit(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Todo todo = db.Todoes.Find(id);
            if (todo == null)
            {
                return HttpNotFound();
            }
            return View(todo);
        }
        // POST: Todoes/Edit/5
        // 過多ポスティング攻撃を防止するには、バインド先とする特定のプロパティを有効にしてください。
        // 詳細については、https://go.microsoft.com/fwlink/?LinkId=317598 を参照してください。
        [HttpPost]
        [ValidateAntiForgeryToken]
        public ActionResult Edit([Bind(Include = "Id,Sammary,Detail,Limit,Done")] Todo todo)
        {
            if (ModelState.IsValid)
            {
                db.Entry(todo).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(todo);
        }
        // GET: Todoes/Delete/5
        public ActionResult Delete(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Todo todo = db.Todoes.Find(id);
            if (todo == null)
            {
                return HttpNotFound();
            }
            return View(todo);
        }
        // POST: Todoes/Delete/5
        [HttpPost, ActionName("Delete")]
        [ValidateAntiForgeryToken]
        public ActionResult DeleteConfirmed(int id)
        {
            Todo todo = db.Todoes.Find(id);
            db.Todoes.Remove(todo);
            db.SaveChanges();
            return RedirectToAction("Index");
        }
        protected override void Dispose(bool disposing)
        {
            if (disposing)
            {
                db.Dispose();
            }
            base.Dispose(disposing);
        }
    }今回はユーザーModelは使わないので、割愛します。
ではここからは、下記の内容に分けて記事を書いていきます!
- INDEXメソッドでログイン中ユーザーに関連する情報のみ取得する
- Detailsメソッドでログイン中ユーザーの情報以外見れないようにする
- Createメソッドでログイン中ユーザーの情報を付与して登録する方法


 
	
コメント