Monthly Archives: Փետրվար 2008

Փոքր Public Հայտարարություն: Windows Live անվտանգության պարամետրերը, եւ շփումների Տիեզերական սեփականատերերին

Ստանում եմ մի բուռ է հաղորդագրություններից են անհատների միջոցով Ներկառուցված "ուղարկել հաղորդագրություն" ֆունկցիան Microsoft առաջարկում կենդանի բացատների (որը նույնպես ընթանում է իմ սեփական օրագիրը) Ամեն ամիս.

Մոտ մեկ երրորդը ժամանակ, those users have secured their live spaces account such that I cannot reply. This is some kind of anti-spam feature I assume.

</վերջ>

Պարզ բացատրություն: “Value չի ընկնում շրջանակներում սպասվող տիրույթում է.”

ԹԱՐՄԱՑՆԵԼ: An anonymous poster left a great comment about internal names. Be sure to read it.

Երբ աշխատում միջոցառման ստացողի եւ այլ կոդը, որը հղում Sharepoint ցուցակի նյութեր միջոցով օբյեկտային մոդելը, Ես հաճախ սխալներ, որոնք առաջացնում այդ սխալը է: Runtime:

Error բեռնում եւ վազում միջոցառումը ընդունիչ Conchango.xyzzyEventReceiver է xyzzy, Տարբերակ = 1.0.0.0, Մշակույթ = չեզոք, PublicKeyToken = 0dc50a750396c3ac. Additional information is below. : Value does not fall within the expected range.

I think this is a fairly generic error that is potentially caused many different ways. Սակայն, one simple explanation is that I’m referencing a field incorrectly. If the name of the field is "Due Date", Ես պետք է հղում, որ նման այս իրադարձության ստացողի:

properties.ListItem["Due Date"]

Երբ ես տառասխալ անել կամ օգտագործել սխալ դեպքը, երբ հիշատակում դաշտը, SharePoint generates the above mentioned runtime error. Օրինակ,, սա սխալ է:

properties.ListItem["due Date"]

</վերջ>

Անդամագրվել իմ բլոգում.

Արորդիների Tags:

End User Quick Tip: Տեսակավորել դիտում փաստաթղթի Գրադարան, Ցուցակ, եւ այլն:.

Մենք կարող ենք, պետք է ստեղծել եւ մի շատ դիտում SharePoint ցուցակներում (Փաստաթղթաշրջանառության գրադարաններ, Պատվերով ցուցակները, եւ այլն:). SharePoint always lists available views in alphabetical order. We cannot change this using out of the box functionality. If it can be done via customization (եւ ես վստահ չեմ, որ այն կարող է), դա հեռու է տեխնիկական ձեր տիպիկ վերջը մասին.

Եթե ​​ցանկանում եք վերահսկել կարգը, որի SharePoint ցուցակներում առկա տեսակետները, պարզապես prepend համար կամ Նամակ դիտիր անունը, ինչպես:

1 – Ըստ նյութական տեսակը
2 – Բոլոր փաստաթղթերը
3 – Due Date

-կամ-

A – Ըստ նյութական տեսակը
B – Բոլոր փաստաթղթերը
C – Due Date

I have also created views whose purpose is strictly to feed a KPI. I have been following this naming convention:

Z_KPI_[նկարագրություն]

That causes my "KPI" դիտում են ներքեւի մասում ցանկում.

</վերջ>

Անդամագրվել իմ բլոգում.

Արորդիների Tags: ,

Կիրակի Զվարճալի: “Երբ ես փոքր տղա”

Որպես ծնող, somewhere along the line I discovered the "When I was a little boy" trick.

Իմ որդին, հավանաբար չորս կամ հինգ ժամանակ, էր նվագում մի փուչիկ է եւ նման շատ փոքր է, որ տղաների հետ խաղալ փուչիկներով, he popped it. He was very upset. The world had come to an end. I said to him, "when I was little boy, Ես ունեի մի փուչիկ, եւ այն popped եւ, ի վերջո,, I got a new balloon." It seemed to help him cope with his loss and led to a fun talk about what it was like when I was a little boy.

That worked well as a consolation technique and I used it a several times over the next period of time. I did get into trouble once when his Monster Rancher 3 creature died. I talked about how my dog, Իշխան, had died in a car accident. Այս անգամ, նրա պատասխանն էր, "Now I feel bad about two things!" I shied away from using the "when I was a little boy" տեխնիկան եւ մխիթարության հետո.

Նախքան մահացած dog միջադեպի, սակայն, I had also started to use the technique to convince him to do chores. "When I was a little boy, I had to go out and get the newspaper", "clean my room", "get Mommy her coffee cup", եւ այլն:.

Սա էլ էր բավականին հաջող մի քիչ, but he started to increasingly rebel against the tyranny of my childhood. One event, մասնավորապես, marked the end. I told him to bring the garbage cans from curb back to the garage. He argued and I responded, "When I was a little boy, I had to take the garbage back to the garage." He responded, "Oh yeah! Well when you were a little boy, որ STUPID!".

</վերջ>

Անդամագրվել իմ բլոգում.

Արորդիների Tags:

Views ու սյուները վերաբերյալ ցուցակներում փաստաթղթերի գրադարանների չի կարելի ապահովել

ԹԱՐՄԱՑՆԵԼ (02/29/08): Այս նոր նախագիծը codeplex թվում է ապահովելու մեթոդ ապահովելու անհատական ​​սյունյակները: http://www.codeplex.com/SPListDisplaySetting. If you have any experience working with it, խնդրեմ թողնել մեկնաբանություն.

Ֆորումի հաղորդագրություններ փակցնողները հաճախ հարց նման: "I have a manager view and and a staff view of a list. How do I secure the manager view so that staff can not use it?"

Նրանք նաեւ հաճախակի ուղղել առնչվող հարցեր: "I want to secure a specific metadata column so that only managers may edit that column while others may not even see it."

These answers apply to both WSS 3.0 եւ MOSS:

  • Sharepoint չի ապահովում out-of-the-տուփի աջակցություն ապահովելու տեսակետները.
  • Sharepoint չի ապահովում out-of-the-տուփի աջակցություն անվտանգության սյուների.

There are several techniques one can follow to meet these kinds of security requirements. Here’s what I can think of:

  • Use out-of-the-box item level security. Views always honor item level security configuration. Event receivers and/or workflow can automate security assignment.
  • Use personal views for "privileged" Դիտումներ. These are easy enough to set up. Սակայն, due to their "personal" բնություն, these need to be configured for each user. Use standard security configuration to prevent anyone else from creating a personal view.
  • Օգտագործեք տվյալների դիտեք վեբ մասը եւ իրականացնել որոշակի AJAXy անվտանգության դրվագ լուծմանը.
  • Գլորում Ձեր ցուցակ ցուցադրման ֆունկցիոնալությունը եւ ներառում անվտանգության դրվագ է սյունակի մակարդակով.
  • Փոփոխել տվյալների մուտքի ձեւերը եւ օգտագործման JavaScript տեխնոլոգիա հետ համատեղ անվտանգության մոդելի իրականացնել շարասյունը մակարդակով անվտանգության դրվագ.
  • Use an InfoPath form for data entry. Implement column-level security trimming via web service calls to SharePoint and conditionally hide fields as needed.
  • Գլորում Ձեր ASP.NET տվյալների մուտքի գործառույթ է իրականացնում սյունակի մակարդակի անվտանգության դրվագ.

Ոչ մեկը, այդ տարբերակներից են այդքան մեծ, բայց գոնե մի ճանապարհ է հետեւել, եթե անհրաժեշտ է, նույնիսկ, եթե դժվար.

Նկատի ունեցեք,: Եթե ​​Դուք որեւէ իջնում ​​այդ ուղիները, don’t forget about "Actions -> Open with Windows Explorer". You want to be sure that you test with that feature to make sure that it doesn’t work as a "back door" եւ հաղթել Ձեր անվտանգության համակարգը.

Եթե ​​ունեք այլ գաղափարներ կամ փորձ, ինչպես ապահովող սյունակներում կամ Դիտումներ, խնդրեմ փոստին ինձ կամ թողնել մեկնաբանություններ եւ ես նորացնել հայտարարությունը ինչպես նաեւ համապատասխան.

</վերջ>

Անդամագրվել իմ բլոգում.

Արորդիների Tags:

Quick Հուշում: BDC ADF տարբերակ թվերը Ձեր Friend

Եթե ​​Դուք ձեռքի կոդավորման ADF ֆայլեր, եւ անում ենք կոդի / ներմուծման / test ցիկլերի, use the version number to make your life easier.

Ես ատում ընդունել այն:, սակայն մինչեւ այս շաբաթ, I was always deleting the ADF and re-importing it. This would break my business data columns and make me re-wire them. All unnecessary.

File this under "it’s obvious once you see it".

Օրինակ:

<LobSystem
xmlns:xsi="http :/://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http :/://schemas.microsoft.com/office/2006/03/BusinessDataCatalog BDCMetadata.xsd" Տիպ="WebService" Տարբերակ="1.2.0.0" Անուն="xyzzyDocumentReview" xmlns="http :/://schemas.microsoft.com/office/2006/03/BusinessDataCatalog">

Փոխել այդ տարբերակը եւ վերագրանցում ներմուծման եւ գործող բիզնես տվյալները շարասյունը օգտագործում է նորացված տարբերակը ինքնաբերաբար առանց լրացուցիչ կարգավորումների պահանջվել.

</վերջ>

Անդամագրվել իմ բլոգում.

Արորդիների Tags:

Լուծում: BDC picker Ցույց միայն մեկ շարասյունը արդյունքները

Իմ ին պատրաստվում փորձերի ապահովելով ավելի օգտակար Փնտրել շարասյունը, օգտագործելով BDC, I hit a wall with the BDC picker. If you haven’t see it, the BDC picker is similar to a people picker except that it works with columns of type "business data".

Դուք մուտք picker սեղմելով բացված գրքի պատկերիկի վրա բիզնես տվյալների սյունակի ինչպես ցուցադրված է:

պատկեր

The above image shows a business data column called "Master Document Id". That column is connected, միջոցով BDC, to a web service. The web service returns two columns of information: Document ID and Title. The business purpose here is to provide a "this document is based on" ֆունկցիա. Users select a "master" փաստաթուղթ, եւ երբ դրանք փրկելու համար, միջոցառում ընդունիչ պատճենները meta տվյալների դաշտերը պարտադիր են Ուղեկցող վարպետի.

Ըստ դեֆոլտի, the BDC picker looks like this when I search for a document whose ID = "38":

clip_image002

Դա օգտակար, but not good enough. People don’t think in terms of IDs, they think in terms of titles and/or other meta data. The picker allows you to search on other columns (e.g. Վերնագիր) բայց չի ցույց փաստացի ցուցակի այն գտել, ուղղակի նրանց DocId ինչ `ինչպես ցուցադրված է այստեղ,:

clip_image002[1]

(Էկրանի անկյունագիծը shot ոչ այնքան մեծ, քանի որ ես չեմ ընտրել այն որոնումը որը վերադառնում որեւէ վավեր արդյունքները, բայց դուք կարող եք տեսնել, որ եթե գտել որոշ արդյունքներ, որ դա ցույց են տվել, DocId ի, ոչ որոնում).

I searched high and low for the answer to this and failed. Իմ գործընկեր, այդ պատվարժան Jonathan Bradshaw, had faced and solved this issue. When I reached out to him for help, Նա նշեց, ինձ ճիշտ ուղղությամբ.

Configure the picker to show multiple columns via the "ShowInPicker" Գույքը է ADF:

<Սեփականություն Անուն="ShowInPicker" Տիպ="System.Boolean">ճիշտ</Սեփականություն>

Ավելի մանրամասն:

  <!-- Վերնագիր -->
  <TypeDescriptor TypeName="System.String" Անուն="Վերնագիր" >
    <LocalizedDisplayNames>
      <LocalizedDisplayName LCID="1033">Վերնագիր</LocalizedDisplayName>
    </LocalizedDisplayNames>
    <Հատկություններ>
      <Սեփականություն Անուն="DisplayByDefault" Տիպ="System.Boolean">ճիշտ</Սեփականություն>
      <Սեփականություն Անուն="ShowInPicker" Տիպ="System.Boolean">ճիշտ</Սեփականություն>
    </Հատկություններ>
  </TypeDescriptor>

Setting this property does introduce a minor problem. As soon as you set it once, you need to set it for every column you want to show. Իմ դեպքում,, BDC picker showed DocId by default. Սակայն, once I added "ShowInPicker" Ինչպես վերնագրի, DocId no longer displayed. I solved that by explicitly setting the ShowInPicker property for Doc ID.

Ահա արդյունքը:

պատկեր

(I’ll explain the odd-looking "168 – CamlSchema.xsd" construction in a future blog post. Մի խոսքով, դա concatenated տողը որը թույլ է տալիս մի փոքր ավելի լավ Օգտվողի փորձ).

Իհարկե, որոնք գրված այս բլոգ - գրառմանը, I just did a search for "ShowInPicker" եւ գտնվել է բազմաթիվ քանակին, այդ թվում `այս մեկը: http://msdn2.microsoft.com/en-us/library/ms583986.aspx. It explains the meaning of that property along with some other good BDC stuff.

</վերջ>

Անդամագրվել իմ բլոգում!

Արորդիների Tags:

Արագ & Հեշտ: Ստեղծել թղթապանակ եւ վերագրելը մի Content type (Կամ, Ունեք Ձեր KPIs կերեք նրանց Too)

Որպեսզի աշխատանքի շուրջ KPI խնդիրը Ես գրել այստեղ:, I did some testing and discovered that KPI’s work against folders with meta data in the same way that they work against documents or list items. I proved it out by creating a new content type based on the folder content type and then added a few fields. I created some indicators and proved to myself that KPIs work as expected. This was welcome news. It’s not perfect, because the drill-down you get from the KPI against the folders is not exactly what you want. This isn’t too much a drawback in my case because 1) Վերջ օգտվողները չգիտեմ որեւէ ավելի ու 2) the drill-down goes to a folder. They click the folder name and they are at the item. It’s two clicks instead of one, որը ոչ թե աշխարհի վերջը.

This flowed nicely with the work I was doing. I am creating a folder for every document that gets uploaded. This is done via an event receiver. Արդյունքում, դա մի կտոր տորթ պահել ծնող պահոցը ի meta data in sync with the KPI-driven meta data from the file itself since the plumbing is already in place. Սա թույլ է տալիս ինձ, որ իմ KPI եւ ուտել նրանց էլ 🙂

I modified the event receiver to add the folder and then set this new folder’s content type to my custom KPI-friendly content type. This bit of code did the trick:

 SPFolderCollection srcFolders = targetWeb.GetFolder("Documents").SubFolders;
  SPFolder addedFolder = srcFolders.Add(properties.ListItem.ID.ToString());
  SPContentTypeId kpiCT = նոր SPContentTypeId("0x0120002A666CAA9176DC4AA8CBAA9DC6B4039F");
  addedFolder.Item["Content Type ID"] = KpiCT;
  addedFolder.Item.Update();

To կմնա փաստացի Content type ID-ն, I մուտք, որ բովանդակության տեսակը միջոցով Տեղում պարամետրերով եւ տետրերի / pasted այն է հղում ինչպես ցուցադրված է:

պատկեր

</վերջ>

Անդամագրվել իմ բլոգում!

Արորդիների Tags: ,

Արագ եւ հեշտ: Ստացեք SPFolder վրա SPListItem է միջոցառման ընդունիչ

Ես ատում ընդունել այն:, but I struggled with this one all day. My event receiver needs to update a field of its parent folder. This little bit shows how to do it:

անձնական անվավեր UpdateParentFolder(SPItemEventProperties հատկություններ)
{

SPFolder thisItemFolder = properties.ListItem.File.ParentFolder;
thisItemFolder.Item[«ZZ հաստատում կարգավիճակը"] = «Լավ լուր, բոլորը!";
thisItemFolder.Item.Update();


} // UpdateParentFolder

Այս դեպքում, Ես աշխատում է մի փաստաթղթի գրադարան եւ հատկությունների են գալիս որպես ItemAdded իրադարձության.

Որ հնարք է, որ դուք չեք կարող ստանալ SPFolder ին կետի անմիջապես կետի մեջ (i.e. properties.ListItem.Folder առ). Փոխարեն, գնալ ցանկ Նյութի վերաբերյալ ի ասոցացված ֆայլը եւ ստանալ ֆայլի ի թղթապանակը.

</վերջ>

Անդամագրվել իմ բլոգում!

Արորդիների Tags:

Yet Another Event ընդունիչ Debug Trick

I’m sure I’m not the first person to come up with this. Սակայն, I haven’t noticed anyone publish a trick like this since I started paying close attention to the community last July. Այնքան, Մտածեցի ես փակցնելու համար սա արագ եւ հեշտ debug հուշում.

Ես աշխատում միջոցառման ստացողի, որը սկսել է առաջացնում այդ սխալի է 12 փեթակ:

Error բեռնում եւ վազում միջոցառումը ընդունիչ Conchango.xyzzyEventReceiver է xyzzy, Տարբերակ = 1.0.0.0, Մշակույթ = չեզոք, PublicKeyToken = blahbalhbalh. Additional information is below. : Object հղում չէ որեւէ ատյանի օբյեկտի.

I didn’t know where I had introduced this bug because I had done too many things in one of my code/deploy/test cycles.

Ես փորձեցի Այս լուծումը ստանալ իմ pdb այնտեղ հետ կապված հույսերը, որ Sharepoint է 12 փեթակ էր ցույց տալ դեղ հետք, բայց ոչ luck. I don’t know if it’s possible and if someone does, խնդրեմ ինձ տեղյակ պահեք 🙂

Ես գիտեմ, որ դա հնարավոր է գրեք ձեր սեփական տեղեկամատյան Հաղորդագրություններ համար 12 փեթակ. Frankly, Ես ուզում էի մի բան, մի քիչ պակաս Մարտական ​​Մոլախաղեր եւ ավելի արագ իրականացնել.

Այն առաջացել է ինձ, որ ես կարող եմ գոնե որոշ հիմնական տեղեկություններ, հետք են բռնում, եւ կրկին նետում ջեներիկներ բացառություններ նման:

  փորձել {
    UpdateEditionDate(հատկություններ);
  }
  բռնել (Բացառություն իսկ)
  {
    նետում նոր Բացառություն("Dispatcher, UpdateEditionDate(): Բացառություն: [" + e.ToString() + "].");
  }

Սա ցույց տվեց, վեր է 12 փեթակ thusly:

Error բեռնում եւ վազում միջոցառումը ընդունիչ Conchango.xyzzyEventReceiver է xyzzy, Տարբերակ = 1.0.0.0, Մշակույթ = չեզոք, PublicKeyToken = blahblahblah. Additional information is below. : Դիսպետչեր, UpdateEditionDate(): Բացառություն: [System.NullReferenceException: Object հղում չէ որեւէ ատյանի օբյեկտի. at Conchango.xyzzyManagementEventReceiver.UpdateEditionDate(SPItemEventProperties հատկությունները) at Conchango.xyzzyManagementEventReceiver.Dispatcher(SPItemEventProperties հատկությունները, String eventDescription)].

Դա ինձ բոլոր մանրամասն I անհրաժեշտ հետեւելու են տվյալ խնդիրը, եւ ես ակնկալում օգտագործել այն շատ գնում է առաջ.

</վերջ>

Անդամագրվել իմ բլոգում!