Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,036

HOME > .NET Framework > Forum > ใครพอจะมีแนวทางกำหนดสิทธิ์เข้าใช้งานโปรแกรมของแต่ละ User บ้างครับ



 

ใครพอจะมีแนวทางกำหนดสิทธิ์เข้าใช้งานโปรแกรมของแต่ละ User บ้างครับ

 



Topic : 111341



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook



คือผมอยากกำหนดสิทธิ์การใช้งานเริ่มตั้งแต่คนส่งเอกสารถึงผู้บริหารอ่ะครับ
แต่ไม่อยากให้มันตายตัวคือสามารถแก้ได้เรื่อยๆ ต้องเขียนรูปแบบยังไงศึกษาตรงไหนครับ



Tag : .NET, Win (Windows App), C#, VS 2012 (.NET 4.x), Windows







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2014-09-16 09:27:51 By : lamaka.tor View : 5184 Reply : 9
 

 

No. 1



โพสกระทู้ ( 213 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


ผมใช้ database ครับ แต่ของผมเขียน web app นะ

หลักการกว้างๆ ของผมคือ ในแต่ละ page user จะทำได้ 4 แบบกับ form คือ view, new, edit, delete

ในตารางกำหนดสิทธิ์ มี column page, userid, view, new, edit, delete อยากให้ user ทำอะไรได้ผมก็ใส่ไว้ตรงนี้

แต่เท่านี้ไม่พอครับ เจ้าของงานเขาอยากให้ไปถึงระดับ กำหนดสิทธิ์ใน control button เลยทีเดียว ปวดหัวครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-16 21:07:56 By : Aod47
 


 

No. 2



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ผมทำ Win App ครับ
คือประมาณว่า อยากทำแบบเปิดหน้าโปรแกรมขึ้นมา
แล้วบล็อกว่าแผนกนี้ให้เปิดการใช้งาน method นี้ได้อีกแผนกไม่ได้
และยังระบุตามตำแหน่งว่าทำอะไรได้บ้างอ่ะครับ
แล้วหากจะแก้ไขก็ไม่ต้องเขียนแล้วคอมไพล์ใหม่ประมาณนั้นครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 08:47:11 By : lamaka.tor
 

 

No. 3



โพสกระทู้ ( 296 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

เรื่องการกำหนดสิทธิ์นี่ผมเขียนมาก็เยอะหลสยระบบ แต่ไม่เหมือนกันซักโปรแกรม
มีอยู่ 2 แบบที่ผมเขียน ตามรูป

กำหนด

แบบที่ 1 ใช้แนวคิดแบบ(แบบชื่ออะไรไม่รู้เหมือนกันไม่ได้คิดไว้) คือเมื่อเพิ่มผู้ใช้ไปแล้ว โปรแกรมจะไปเพิ่มในตาราง tblsystems และ tblprivilage ที่เราสร้างไว้ด้วย พอผู้ใช้กด button หรือเข้าเมนูนั้นให้เราสร้าง sub function เช็คดูอีกที
ระบบ

เมื่อมีการเรียกใช้งาน Form ก็ให้เช็ค โดยการส่งระหัสของระบบเข้าไปเช็คดู
Code (VB.NET)
Private Sub frmMember_Shown(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Shown
        Try
            CheckPrivilege("00001")
        Catch ex As Exception
            Me.Close()
            MessageBox.Show("คุณไม่มีสิทธิการเข้าใช้งานในส่วนนี้", "สิทธิการเข้าถึง", MessageBoxButtons.OK, MessageBoxIcon.Warning)
        End Try
    End Sub

Code (VB.NET)
 Public Function CheckPrivilege(ByVal sysid As String) As Boolean
        Thipmanee_Media_Network_Customer_Management_System.MDIMain.Reconnect()
        Dim strPrivilege As String = String.Format("SELECT tblprivilege.*,tblsystem.* FROM tblprivilege,tblsystem WHERE tblprivilege.SystemID = tblsystem.SystemID AND tblprivilege.EmployeeID = '{0}' AND tblprivilege.SystemID = '{1}' LIMIT 1", Thipmanee_Media_Network_Customer_Management_System.MDIMain.strEmpID, sysid)
        MyAd.SelectCommand.CommandText = strPrivilege
        MyAd.Fill(DS, "tblprivilege")

        If Not Convert.ToBoolean(DS.Tables("tblprivilege").Rows(0)("IsUsing")) Then
            Me.Close()
'เข้าไม่ได้ก็ให้มีข้อความ
            MessageBox.Show("คุณไม่มีสิทธิการเข้าใช้งานในส่วนนี้", "สิทธิการเข้าถึง", MessageBoxButtons.OK, MessageBoxIcon.Warning)
        End If
'เปิด/ปิดปุ่มเพิ่ม
        If Convert.ToBoolean(DS.Tables("tblprivilege").Rows(0)("IsAdd")) Then
            BindingNavigatorAddNewItem.Enabled = True
        Else
            BindingNavigatorAddNewItem.Enabled = False
        End If
'เปิด/ปิดปุ่มลบ
        If Convert.ToBoolean(DS.Tables("tblprivilege").Rows(0)("IsDel")) Then
            BindingNavigatorDeleteItem.Enabled = True
        Else
            BindingNavigatorDeleteItem.Enabled = False
        End If
'เปิด/ปิดปุ่มแก้ไข
        If Convert.ToBoolean(DS.Tables("tblprivilege").Rows(0)("IsEdit")) Then
            TSBSave.Enabled = True
        Else
            TSBSave.Enabled = False
        End If

        DS.Tables("tblprivilege").Clear()

        Return True
    End Function


ตามนี้ครับอธิบายไม่ถูก
================================================================
ส่วนแบบที่สองนั้น ตามรูปภาพที่ 1 จะเห็นว่า ตาราง User จะมี ฟิลดฺ์ที่ชื่อระบบของแต่ละระบบมีค่าเป็น 0 กับ 1 และเอา chekbox มารับค่า ระบบแบบที่สองนี้ถ้ามีการเพิ่มระบบใหม่เข้าไปในโปรแกรมเราก็ต้องไปเพิ่มฟิลด์ใหม่และ Checkbox ใหม่ ซึ่งก็ fix นั่นแหละนะ(ไม่ค่อยยืดหยุ่น) อันนี้จะกำหนดได้แค่ เข้าระบบได้หรือไม่ได้เท่านั้น ซึ่งถ้าเข้าได้แล้วนั้นเข้าไปทำอะไรอันนั้น ก็ต้องเขียนเพิ่มอีกทีอยู่ที่ความต้องการของผู้ใช้และโปรแกรมเมอร์ที่ต้องเขียนว่าจะให้ทำอะไรมั่ง ผมเห็นว่าระบบแบบที่ 1 จะยืดหยุ่นกว่านิดหน่อยที่ผู้ใช้สามารถเพิ่มระบบเองได้ แต่จะมีข้อเสียคือ ระบบที่เพิ่มเข้ามาภายหลัง ผู้ใช้ที่เคยเพิ่มเข้าไปก่อนจะไม่สามารถใช้ระบบที่เพิ่มเข้ามาใหม่ได้ แต่ผมคิดนะ ถ้ามีระบบใหม่เข้ามา โปรแกรมเมอร์ก็ต้องมานั่งเขียนอยู่ดีผมจึงเลือกใช้ แบบที่สองดีกว่า Manage ง่ายและเข้าใจง่ายดี

อันนี้อยู่ที่แนวคิดของโปรแกรมเมอร์แล้วหละครับว่าจะนำไปปรับปรุงเข้ากับการใช้งานของโปรแกรมเราอย่างไร

ปล.ใครมีแนวคิดอื่นช่วยแชร์ด้วยนะครับ ผมก็เขียนมาหลายโปรแกรม ก็มีปัญหากับแนวคิดเรื่องการกำหนดสิทธิ์ของผู้ใช้อยู่พอสมควร ระบบแต่ละระบบไม่เหมือนกันมันปวดหัว อย่างกับความเห็นที่ 1 ว่านั่นแหละครับ อิอิ

*****แบบที่ 1 โปรแกรมเมอร์คนเก่าเขาเขียนไว้ ซึ่งผมนำมาแก้ไขเพิ่มเติมอีกที


ประวัติการแก้ไข
2014-09-17 09:22:48
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 09:19:04 By : zarooman
 


 

No. 4



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

แหล่มเลยพอได้แนวทางแระ
ขอบคูณมากครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 10:15:23 By : lamaka.tor
 


 

No. 5

Guest


เราใช้ role & membership provide ที่มากับ .net

http://www.codeproject.com/Articles/281573/ASP-NET-Membership-and-Role-Provider

http://www.codeproject.com/Articles/342061/Understanding-ASP-NET-Roles-and-Membership-A-Begin

ในลิงค์มันแค่ตัวอย่าง เวลาเราทำจริง มันจะเหลือแต่ class role, user และ database

จะกำหนดสิทธิ์การเข้าถึงก็กำหนดที่ web.config ของแต่ละ folder เลย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 11:58:23 By : ห้ามตอบเกินวันละ 2 กระทู้
 


 

No. 6

Guest


กลับมาตอบอีกที หลังจากเพิ่งรู้ว่าคุยกันเป็น desktop app

หน้าแตกเลย อิอิ

ถ้าเป็น winform ลองใช้ active directory authentication ดู
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 13:48:36 By : ห้ามตอบเกินวันละ 2 กระทู้
 


 

No. 7



โพสกระทู้ ( 4,440 )
บทความ ( 23 )



สถานะออฟไลน์
Facebook

ครับ
เรื่องนี้ถามเผื่อไว้คาดวาน่าจะอีกนาน
ตอนนี้ทยอยทำ .dll ย่อยไปก่อนถ้ารวมเป็นโปรแกรมใหญ่ทั้งระบบคงต้องได้ใช้
ตอนนี้ระบบยังอยู่ในระดับหน่วยงานอยู่ครับ
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 14:08:03 By : lamaka.tor
 


 

No. 8



โพสกระทู้ ( 66 )
บทความ ( 0 )



สถานะออฟไลน์


แนวๆ นะครับ ผมใช้ SharpDevelop
void Button1Click(object sender, EventArgs e)
{
string lavel = "TC3" ;
string lavell = "TC2";
string lavelll = "TC1" ;
if(txpass.Text != "")
{
if(chackuser(txpass.Text) == true)
{
groupBox1.Visible = true ;
txpass.Text = "";
txpass.Visible = false ;
button1.Visible = false;
tbpass.Visible = false;
label1.Text = "";
if(lblavalll.Text == lavel)
{
menuStrip1.Enabled = true;
//comboBox1.Enabled = true;
button3.Enabled = true;
button4.Enabled = true;
button5.Enabled = true ;

}
else
{
if(lblavalll.Text == lavell)
{
menuStrip1.Enabled = false;
//comboBox1.Enabled = true;
button3.Enabled = false;
button4.Enabled = false;
button5.Enabled = true ;

}
else
{
menuStrip1.Enabled = false;
//comboBox1.Enabled = false;
button3.Enabled = false;
button4.Enabled = false;
button5.Enabled = true ;

}

}
}
else
{
label1.Text = "No..User";
tmreset.Enabled = true ;
}
}
else
{
label1.Text = "No..DATA";
tmreset.Enabled = true ;
}
}
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-09-17 16:10:25 By : ต๋องคับ
 


 

No. 9



โพสกระทู้ ( 22 )
บทความ ( 0 )



สถานะออฟไลน์



แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2018-03-20 15:21:35 By : tomsmile05
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ใครพอจะมีแนวทางกำหนดสิทธิ์เข้าใช้งานโปรแกรมของแต่ละ User บ้างครับ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 04
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่