Valhalla Legends Archive

Programming => General Programming => Visual Basic Programming => Topic started by: Tristan on March 07, 2009, 01:50 AM

Title: SeDebugPrivilege Help
Post by: Tristan on March 07, 2009, 01:50 AM
Hey, I'm coding a program that requires me to set SeDebugPrivilege on itself.  It works fine on my system and not on others.  Some people receive the access denied error when they attempt to open the protected process.  I've been googling for a while and I've found a few different solutions, however none of them have worked.

I've tried having them make sure they're in the administrators group, they are.
I've tried adding them to the Debug Programs local permissions group, which they did successfully.

I've tried more things that I can't remember, none have worked. So does anybody know what may be the problem here?

The people getting the problem are mostly on Windows XP.  But I did see one having it on Vista.
Title: Re: SeDebugPrivilege Help
Post by: l)ragon on March 11, 2009, 09:13 AM
vb6?
Title: Re: SeDebugPrivilege Help
Post by: brew on March 11, 2009, 07:55 PM
Quote from: l)ragon on March 11, 2009, 09:13 AM
vb6?

You're in the visual basic forum. I would assume so, yes.
Title: Re: SeDebugPrivilege Help
Post by: Yegg on March 12, 2009, 12:23 AM
Quote from: brew on March 11, 2009, 07:55 PM
Quote from: l)ragon on March 11, 2009, 09:13 AM
vb6?

You're in the visual basic forum. I would assume so, yes.

Ya, but there is also .NET. With this particular topic there may be a big difference between the two.
Title: Re: SeDebugPrivilege Help
Post by: Mystical on March 12, 2009, 04:18 PM
then i believe it'd go to the board above this one in .net section
Title: Re: SeDebugPrivilege Help
Post by: Barabajagal on March 12, 2009, 04:46 PM
Only if this board was labeled legacy Visual Basic. As it is, VB.NET will technically fit into either section by definition.

BTW, not to hijack this thread, but what has everyone been hearing about VB 10? I might hang my .NET hate on a shelf to try it out, just to see if they've improved it any.
Title: Re: SeDebugPrivilege Help
Post by: Yegg on March 12, 2009, 09:07 PM
Quote from: Mystical on March 12, 2009, 04:18 PM
then i believe it'd go to the board above this one in .net section

Then I'd take into consideration the fact that this is a first time poster (hint: he has one post) and thus has a higher chance of placing something in the wrong category.
Title: Re: SeDebugPrivilege Help
Post by: Mystical on March 13, 2009, 05:59 PM
its still vb6, but this was cool, we just blew up a post that had nothing to do with the original question.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 13, 2009, 11:04 PM
Quote from: Andy on March 12, 2009, 04:46 PM
BTW, not to hijack this thread, but what has everyone been hearing about VB 10? I might hang my .NET hate on a shelf to try it out, just to see if they've improved it any.

http://blogs.msdn.com/vbteam/archive/2008/11/02/vb-2010-unveiled-at-pdc-2008-lisa-feigenbaum.aspx

Has some VB2010 features from PDC, more might have been unveiled since then.

However, you really should just make the leap to C#. VB .NET will probably always be a second class citizen in .NET .
Title: Re: SeDebugPrivilege Help
Post by: MyndFyre on March 13, 2009, 11:06 PM
Quote from: Warrior on March 13, 2009, 11:04 PM
However, you really should just make the leap to C#. VB .NET will probably always be a second class citizen in .NET .
That's certainly not the way Microsoft is treating it.
Title: Re: SeDebugPrivilege Help
Post by: Barabajagal on March 13, 2009, 11:24 PM
And in any case, you can usually convert between any of the three major .NET languages with #Develop.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 14, 2009, 08:43 AM
Quote from: MyndFyre[vL] on March 13, 2009, 11:06 PM
Quote from: Warrior on March 13, 2009, 11:04 PM
However, you really should just make the leap to C#. VB .NET will probably always be a second class citizen in .NET .
That's certainly not the way Microsoft is treating it.

Why do you think this? There is a quite obvious artificial crippling of the feature sets in VB.NET.

Just look at the features they're just now getting. It's quite pathetic.
Look no further than the C# 4.0 changes versus the VB.NET changes, the difference is quite clear.

Edit:

To further prove my point

Quote
Visual Basic 2005 introduced features meant to fill in the gaps between itself and other "more powerful" .NET languages, adding:

    * .NET 2.0 languages features such as:
          o generics [3]
          o Partial classes, a method of defining some parts of a class in one file and then adding more definitions later; particularly useful for integrating user code with auto-generated code
          o Nullable Types
    * XML comments that can be processed by tools like NDoc to produce "automatic" documentation
    * Operator overloading [4]
    * Support for unsigned integer data types commonly used in other languages

Source (http://en.wikipedia.org/wiki/Visual_Basic_.NET#Visual_Basic_2005_.28VB_8.0.29)

My point is, Visual Basic, and more recently, Visual Basic .NET, should be avoided like the plague.

Seriously, use C#, it's not that scary.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 14, 2009, 08:43 AM
Quote from: Andy on March 13, 2009, 11:24 PM
And in any case, you can usually convert between any of the three major .NET languages with #Develop.

That's true, but the point of syntax sugar is for it to be used while writing code.
Title: Re: SeDebugPrivilege Help
Post by: MyndFyre on March 14, 2009, 06:40 PM
Quote from: Warrior on March 14, 2009, 08:43 AM
To further prove my point

Quote
Visual Basic 2005 introduced features meant to fill in the gaps between itself and other "more powerful" .NET languages, adding:

    * .NET 2.0 languages features such as:
          o generics [3]
          o Partial classes, a method of defining some parts of a class in one file and then adding more definitions later; particularly useful for integrating user code with auto-generated code
          o Nullable Types
    * XML comments that can be processed by tools like NDoc to produce "automatic" documentation
    * Operator overloading [4]
    * Support for unsigned integer data types commonly used in other languages

Source (http://en.wikipedia.org/wiki/Visual_Basic_.NET#Visual_Basic_2005_.28VB_8.0.29)

My point is, Visual Basic, and more recently, Visual Basic .NET, should be avoided like the plague.

Seriously, use C#, it's not that scary.
Have you ever used Visual Basic .NET? 

Visual Studio 2005 is what deployed .NET 2.0.  Generic types were part of VC# and VB both in Studio 2005, and were not there prior.  Partial classes were introduced in Studio 2005 for both languages.  Nullable types are really an exposure of System.Nullable<T>, introduced in the BCL of .NET 2.0.  VB didn't support the other three items out of the box in 1.x (although people were writing tools to extract XML comments from VB code), but hey, C# doesn't support an intrinsic XML type (http://msdn.microsoft.com/en-us/library/bb531325.aspx), so it must suck.  C# doesn't support the My namespace (http://msdn.microsoft.com/en-us/vbasic/ms789188.aspx), or the with statement (http://msdn.microsoft.com/en-us/library/wc500chb(VS.80).aspx). 

Visual Basic doesn't have crippling feature sets.  In fact at the PDC talks Anders talked a lot about how when one language gets a feature the other typically wants to add it in right away.  They access the same BCL and they're both considered first-class citizens of the .NET world, at least where Microsoft is involved.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 14, 2009, 10:27 PM
Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
Have you ever used Visual Basic .NET? 

Yes.

Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
Visual Studio 2005 is what deployed .NET 2.0.  Generic types were part of VC# and VB both in Studio 2005, and were not there prior.  Partial classes were introduced in Studio 2005 for both languages.  Nullable types are really an exposure of System.Nullable<T>, introduced in the BCL of .NET 2.0.

Of course, however, prior to this, there was a quite noticeable gap in functionality between VB.NET and C#.

Note a lack of overloaded operators, unsafe code, unsigned types, using statements, hell VB until 2005 didn't even have inheritance or interfaces!

You call that a first class citizen? Give me a break.

Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
  VB didn't support the other three items out of the box in 1.x (although people were writing tools to extract XML comments from VB code), but hey, C# doesn't support an intrinsic XML type (http://msdn.microsoft.com/en-us/library/bb531325.aspx), so it must suck.  C# doesn't support the My namespace (http://msdn.microsoft.com/en-us/vbasic/ms789188.aspx), or the with statement (http://msdn.microsoft.com/en-us/library/wc500chb(VS.80).aspx). 

Those are rather weak things to complain about, it's pretty obvious that VB.NET has historically always been a step behind C#.

Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
Visual Basic doesn't have crippling feature sets.  In fact at the PDC talks Anders talked a lot about how when one language gets a feature the other typically wants to add it in right away. 

The language which typically gets the feature first is C#, which is the entire basis behind my argument. C# is at the forefront of .NET development, it's very seldom C# gets features VB has had for a while (The recent exception being named and optional params)

Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
They access the same BCL and they're both considered first-class citizens of the .NET world, at least where Microsoft is involved.

History seems to disagree.
Title: Re: SeDebugPrivilege Help
Post by: MyndFyre on March 14, 2009, 11:10 PM
Quote from: Warrior on March 14, 2009, 10:27 PM
Note a lack of overloaded operators, unsafe code, unsigned types, using statements, hell VB until 2005 didn't even have inheritance or interfaces!
Again, you're wrong: Visual Basic was a fully object-oriented .NET citizen as of 2002 (http://msdn.microsoft.com/en-us/library/y17w47af(VS.71).aspx) when C# debuted.  As far as overloaded operators, unsafe code, and unsigned types, the bottom line is that these are edge cases.  I can count on my hands the number of times I've ever used unsafe code for personal projects and never used it in a professional project.  Overloaded operator creation is also pretty infrequent (how often do you need to reimplement a numeric type?).  And unsigned types are the same thing too - they're not used in the BCL, they're not part of SQL, and even if you could say they're useful for B.net, the bottom line is that lots of people have gotten by without them with VB6.  So... who cares?

Quote from: Warrior on March 14, 2009, 10:27 PM
Quote from: MyndFyre[vL] on March 14, 2009, 06:40 PM
  VB didn't support the other three items out of the box in 1.x (although people were writing tools to extract XML comments from VB code), but hey, C# doesn't support an intrinsic XML type (http://msdn.microsoft.com/en-us/library/bb531325.aspx), so it must suck.  C# doesn't support the My namespace (http://msdn.microsoft.com/en-us/vbasic/ms789188.aspx), or the with statement (http://msdn.microsoft.com/en-us/library/wc500chb(VS.80).aspx). 

Those are rather weak things to complain about, it's pretty obvious that VB.NET has historically always been a step behind C#.
Ever use the My namespace?  Pretty fucking awesome.  Access to ports, audio, user, network stack, application log....  The intrinsic XML type is pretty awesome too.  Did you look at the link I provided? 

Quote from: Warrior on March 14, 2009, 10:27 PM
The language which typically gets the feature first is C#, which is the entire basis behind my argument. C# is at the forefront of .NET development, it's very seldom C# gets features VB has had for a while (The recent exception being named and optional params)
Oh yeah, VB has had optional parameters since... forever.  So has C++, incidentally.  The descendant C#, though, didn't.  Hmmm....

Quote from: Warrior on March 14, 2009, 10:27 PM
History seems to disagree.
I might suggest actually doing some research (http://www.bitwisemag.com/copy/features/vb6/vb_jayroxe-qa.html):
Quote from: Jay Roxe, VB Product ManagerPortions of the CLR are written in C# and portions are written in VB – both languages are first-class citizens on the CLR

I don't believe that differences in the languages make one a second-class citizen. The teams have chosen to invest in different features, but this provides advantages to developers because it gives them a better opportunity to select the tool that's right for the job.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 15, 2009, 12:18 AM
Quote from: MyndFyre[vL] on March 14, 2009, 11:10 PM
Again, you're wrong: Visual Basic was a fully object-oriented .NET citizen as of 2002 (http://msdn.microsoft.com/en-us/library/y17w47af(VS.71).aspx) when C# debuted.

Interesting, I remember reading an article which suggested the contrary. Oh well, good that it's not as bad as I thought.

Quote from: MyndFyre[vL] on March 14, 2009, 11:10 PM
  As far as overloaded operators, unsafe code, and unsigned types, the bottom line is that these are edge cases.  I can count on my hands the number of times I've ever used unsafe code for personal projects and never used it in a professional project.  Overloaded operator creation is also pretty infrequent (how often do you need to reimplement a numeric type?).  And unsigned types are the same thing too - they're not used in the BCL, they're not part of SQL, and even if you could say they're useful for B.net, the bottom line is that lots of people have gotten by without them with VB6.  So... who cares?

There's also partial interfaces, yield, static classes, and auto properties, but the overall point is that it does get features later, regardless of how important you think they are.


Quote from: MyndFyre[vL] on March 14, 2009, 11:10 PM
Ever use the My namespace?  Pretty fucking awesome.  Access to ports, audio, user, network stack, application log....  The intrinsic XML type is pretty awesome too.  Did you look at the link I provided? 

No, they sound neat, but they can most certainly be dismissed in the same manner you dismissed the differences I cited.

Quote from: MyndFyre[vL] on March 14, 2009, 11:10 PM
Oh yeah, VB has had optional parameters since... forever.  So has C++, incidentally.  The descendant C#, though, didn't.  Hmmm....

And how useful are they? C# has function overloading, so the only advantage for them is probably COM Interop.


Quote from: MyndFyre[vL] on March 14, 2009, 11:10 PM
Quote from: Jay Roxe, VB Product ManagerPortions of the CLR are written in C# and portions are written in VB – both languages are first-class citizens on the CLR

I don't believe that differences in the languages make one a second-class citizen. The teams have chosen to invest in different features, but this provides advantages to developers because it gives them a better opportunity to select the tool that's right for the job.

What do you expect him to say? One language has precedence over the other? Obvious they want to cater to a large audience.

Title: Re: SeDebugPrivilege Help
Post by: brew on March 15, 2009, 08:23 AM
I don't understand why Warrior fails to see that they - as two separate languages - have different goals and audiences. Even the Express websites highlight this fundamental difference in the product descriptions.
Visual Basic '08: "Productivity that is ideal for first time or casual Windows programming."
C# '08: "A great combination of power and productivity for the Windows developer."
It should be obvious that by being developed by two different camps, each will inject their own philosophy, with different ideas of how their language should be, what features work for them, what would benefit the target audience the most, etc. Not necessarily the most powerful to develop with.
Of course it's obvious microsoft may tend to lean on the C# side (you seriously can't forget the aura Visual Basic left behind, plus C# has a load of java nuts and people who were disappointed with C++ .NET) so I agree with Warrior. Not to the extent he does, though.
C'mon, no politics threads on x86, so you bring your ranting and raving over here? Try making a productive post once in a while. I don't really see anything going on here except your e-peenor extending.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 15, 2009, 08:30 AM
Quote from: brew on March 15, 2009, 08:23 AM
I don't understand why Warrior fails to see that they - as two separate languages - have different goals and audiences. Even the Express websites highlight this fundamental difference in the product descriptions.
Visual Basic '08: "Productivity that is ideal for first time or casual Windows programming."
C# '08: "A great combination of power and productivity for the Windows developer."
It should be obvious that by being developed by two different camps, each will inject their own philosophy, with different ideas of how their language should be, what features work for them, what would benefit the target audience the most, etc. Not necessarily the most powerful to develop with.
Of course it's obvious microsoft may tend to lean on the C# side (you seriously can't forget the aura Visual Basic left behind, plus C# has a load of java nuts and people who were disappointed with C++ .NET) so I agree with Warrior. Not to the extent he does, though.
C'mon, no politics threads on x86, so you bring your ranting and raving over here? Try making a productive post once in a while. I don't really see anything going on here except your e-peenor extending.

tl;dr I reach the same conclusion Warrior reached, only I inject large amounts of stupid inbetween.

edit: ew you browse x86, yuck, ban it.
Title: Re: SeDebugPrivilege Help
Post by: brew on March 15, 2009, 09:02 AM
I figured I'd get a stupid response.
Oh well, I think you're just butthurt about being trolled. How does it feel to be trolled, troll?
Title: Re: SeDebugPrivilege Help
Post by: Yegg on March 15, 2009, 09:37 AM
Regardless what anyone thinks, we need threads with content like this. When two intelligent people such as MyndFyre and Warrior debate on a topic where they both know a great deal of info on, others can learn from it -- which is largely what this forum has been used for.
Title: Re: SeDebugPrivilege Help
Post by: Warrior on March 15, 2009, 10:22 AM
Well, my original point (Due to what I was led to believe by another article) might have been a little over the top, so Myndy is correct in that there's much less of a rift than I thought.

As for brew, I really do not pay him any mind, he strikes me as pedantic, though I'm not even sure that applies because it requires him to actually be intelligent. Ah well.
Title: Re: SeDebugPrivilege Help
Post by: brew on March 15, 2009, 10:27 AM
Oh come on, get real Yegg. The activity should lie within the new members. Unfortunately, the only new members on this board are:
70%: People who want help with D2GS packet compression, so they can make d2 botz to farm items.
20%: People who want help with making a winbot, and/or battle.net loader robot.
10%: People who see vL as this amazing and active clan, and figure they'd sign up for the hell of it and never post.
Title: Re: SeDebugPrivilege Help
Post by: Yegg on March 15, 2009, 07:38 PM
Quote from: brew on March 15, 2009, 10:27 AM
Oh come on, get real Yegg. The activity should lie within the new members. Unfortunately, the only new members on this board are:
70%: People who want help with D2GS packet compression, so they can make d2 botz to farm items.
20%: People who want help with making a winbot, and/or battle.net loader robot.
10%: People who see vL as this amazing and active clan, and figure they'd sign up for the hell of it and never post.

So why even bring this up? It seems like all the newest members just learned partial English three weeks ago anyway. The existing (and mainly longterm members) are the ones continuing to keep some kind of useful content on the website. They do this by threads like this, and by answering an occasional question by a newcomer (which are extremely rare now) or existing member.
Title: Re: SeDebugPrivilege Help
Post by: brew on March 15, 2009, 09:31 PM
Then it's settled. We argue with eachother.
Title: Re: SeDebugPrivilege Help
Post by: MyndFyre on March 15, 2009, 10:03 PM
Quote from: brew on March 15, 2009, 09:31 PM
Then it's settled. We argue with eachother.

No we don't.
Title: Re: SeDebugPrivilege Help
Post by: Barabajagal on March 15, 2009, 10:10 PM
Brew, shut up.
Warrior, stop arguing against the existence of a language you don't like. Why do you pretend to care? You know you don't.
Mynd, you're a moderator, aren't you? Why are you allowing this kind of off-topic crap in the thread of someone asking for knowledge that this site is used for?

This is ridiculous.
Title: Re: SeDebugPrivilege Help
Post by: brew on March 15, 2009, 11:04 PM
Shut up andy, flow with it or be a sore thumb. But seriously. I don't see anything wrong with off topic crap when it's the only crap we have to work with.
Title: Re: SeDebugPrivilege Help
Post by: Yegg on March 16, 2009, 12:22 AM
Quote from: brew on March 15, 2009, 11:04 PM
Shut up andy, flow with it or be a sore thumb. But seriously. I don't see anything wrong with off topic crap when it's the only crap we have to work with.

Agreed. Off-topic content is good for now, considering without it the current forum activity would decrease significantly.
Title: Re: SeDebugPrivilege Help
Post by: MyndFyre on March 16, 2009, 12:23 AM
Quote from: Andy on March 15, 2009, 10:10 PM
Mynd, you're a moderator, aren't you? Why are you allowing this kind of off-topic crap in the thread of someone asking for knowledge that this site is used for?
Not a moderator of this forum, no.  But a lot of this discussion, while off-topic for the particular thread, isn't necessarily off-topic for the forum.  So, meh.
Title: Re: SeDebugPrivilege Help
Post by: MysT_DooM on March 16, 2009, 02:01 PM
Quote from: Tristan on March 07, 2009, 01:50 AM
Hey, I'm coding a program that requires me to set SeDebugPrivilege on itself.  It works fine on my system and not on others.  Some people receive the access denied error when they attempt to open the protected process.  I've been googling for a while and I've found a few different solutions, however none of them have worked.

I've tried having them make sure they're in the administrators group, they are.
I've tried adding them to the Debug Programs local permissions group, which they did successfully.

I've tried more things that I can't remember, none have worked. So does anybody know what may be the problem here?

The people getting the problem are mostly on Windows XP.  But I did see one having it on Vista.

Well i've read a bit, and am thinking you might have to change the access tokens of the process. So did you try to adjust the tokens privileges?  What did you try to do?
I read some more now, did you try looking into CreateProcessAsUser(), I believe that will get you to launch a process with a specified token, but I believe you'd have to change the security descriptor of that access token to allow that. This is alot of token business, anyways the following links might be more insightful, but i'll probably mess around with this later:


Access Rights for Access-Token Objects (http://msdn.microsoft.com/en-us/library/aa374905(VS.85).aspx)
AdjustTokenPrivileges Function (http://msdn.microsoft.com/en-us/library/aa375202(VS.85).aspx)
GetSecurityInfo Function (http://msdn.microsoft.com/en-us/library/aa446654(VS.85).aspx#)
KillProcess - Terminate any application, shows token changing examples (http://binaryworld.net/Main/CodeDetail.aspx?CodeId=1551)