質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Q&A

1回答

661閲覧

ユーザー登録を行う際に権限を分けて登録したい。

ryomann

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

0グッド

0クリップ

投稿2021/12/16 06:18

前提・実現したいこと

ユーザー登録を行う際に権限を分けて登録したい。

発生している問題・エラーメッセージ

現在就活相談予約アプリをlaravel作っています。
そこで、予約する側、予約される側で処理を分ける必要が出てきました。
DBのUsersテーブルにroleカラム(true:予約される側 false:予約する側)を用いて認可の処理を書いていたところ、
ユーザー登録を行う際どうやってroleカラムにtrueをいれるかfalseを入れるか判断するのかがわかりませんでした。

試したこと

自分で思いついたこと
①予約される側、予約する側以外に、管理者の権限を作り、管理者が権限を逐一付与する。
→予約される側、予約する側の人数が多い場合に効率が悪そう。

②ユーザー登録画面を予約される側、予約する側で分けて作り、予約される側のユーザー登録画面にはパスワードがないと入れないようにする。
→セキュリティ的に大丈夫なのか?

問題がなければ②で実装しようと思っています。
実務ではどのように登録しているのかを教えてもらえると幸いです。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2021/12/16 16:13

やり方は色々考えられますね。就活サイトといっても会社側と求職者に分かれてるならそもそもテーブルどころかサイト自体を分ける場合もあるでしょうし、teratail みたいに誰でも質問も回答もできるなら分ける必要もないし…。 予約される側と予約する側を、誰がどういう基準で分けるかによるんじゃないでしょうか。
guest

回答1

0

Userテーブルにroleカラムを設置してあるならば、userとroleは1対1関係ですね。既に一つのuserは一つのroleしか持てない。という意味は、別のroleを得るために新しいアカウントを作成しなければいけません。
実現したい事を見ると、一人のuserに複数のroleを与えたいようですね。各roleも複数のuserを持つことができます。ならばuserとroleは多対多関係であります。中間テーブルuser_rolesを作り上げて、user_idとrole_idを保存すればuserにroleを与えられます。

投稿2021/12/16 07:32

skys215

総合スコア910

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ryomann

2021/12/16 09:43

回答ありがとうございます。 質問が明確でなくて申し訳ないです。 質問したかったことは、一人のuserに複数のroleを与えるということではなかったです。 DB設計ではなく、ユーザー新規登録する際にDBにユーザー情報をinsertする処理する前にユーザーにどの権限を与えるかを判断しなければならないと思います。 どの権限を与えるかという処理はユーザーが新規登録をした際に普通書くのでしょうか? teratailで具体例をだすと、 私たち一般ユーザーと運営ユーザー(複数アカウントあるとする)とでは与えられている権限が違うと思います。 運営ユーザーと一般ユーザーの権限をDBに登録する処理はいつ書かれているのでしょうか。 自分は、 運営ユーザーの新規登録画面と一般ユーザーの新規登録画面を分けることによってDBに登録する権限を判断しているのかな?と想像しています。 分かりにくいかと思いますが回答していただけると助かります。
skys215

2021/12/17 01:56

理解間違えてすみません。 各ユーザーは予約すると予約される両方できるなら、ログインの時にチェックボックスで区分したらどうでしょうか?sessionに保存すればいいと思います。データーベースに保存しなければいけない理由はありますか? 一般ユーザーと運営ユーザーの場合は、権限が違う為、個人的には別のテーブルに保存します。既に運営ユーザーは質問や回答できません。でも具体的の要件に異なります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問