Category Archives: SharePoint উন্নয়ন

SharePoint সাথে আলাপচারিতার বাঁশ ক্যালেন্ডার "একটি অপ্রত্যাশিত ত্রুটি ঘটেছে" কারণ

আজ, I’ve been working in an environment that uses a Bamboo calendar web part for some improved collaboration. This a standard medium/small farm with two load balanced WFEs, ইন্ডেক্স এবং InfoPath এবং ক্লাস্টার করা এসকিউএল ফিরে শেষ জন্য একটি "অ্যাপ্লিকেশন সার্ভারের".

The client installed some disaster recovery software onto one of the WFEs and that resulted in a broken WFE for a specific site in the site collection. Whenever load balancing pointed at the affected WFE and that site, users saw a largely blank white screen with the sentence “An unexpected error occurred”. No other info showed, শুধু যে বাক্য.

They asked me to look at it. I easily reproduced the problem and then added a ?contents=1 to the end of the URL. This is how I learned they were using the Bamboo web part. I went back to the page and now, হঠাৎ, এটা আমার একটা চমৎকার সুশৃঙ্খল ত্রুটির বার্তা দেখিয়েছে:

image

আমি সংযোজন আর অন্য প্রদর্শন নিয়ন্ত্রিত ত্রুটি বার্তা পেতে কি ঘটছে বা কি না জানি না ?contents=1 bit of the query string.

এটি সম্ভবত একটি খুব বিরল প্রান্ত ক্ষেত্রে কিন্তু আপনি যে বার্তা পেতে হলে, "একটি অপ্রত্যাশিত ত্রুটি ঘটেছে" এগিয়ে যান এবং যোগ ?ক্যোয়ারী স্ট্রিং বিষয়বস্তু = 1 এবং যে জন্মাতে কোথায়.

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

টুইটারে আমার অনুসরণ http://www.twitter.com/pagalvin

Technorati বিভাগ: ,

Microsoft.SharePoint.dll নেভিগেশন প্রতিফলক ব্যবহার করে

Redgate .NET Reflector মাইকেল Blumenthal একটি আপ করা হয়েছে সতর্কতা ও মতামত সম্পর্কে নিবন্ধ ("Which views can be used when Creating an Alert ?"), which is interesting on its own merits. কিন্তু, I was even more interested to see how he methodically walks through the process of using Redgate’s .NET Reflector. Step by step, he shows how to use that tool track down how SharePoint determines whether a view on a list should be "subscribable" জন্য একটি ভাল শব্দ অভাব (he explains this much better than I do 🙂 ).

SharePoint যুগের এই সময়ে, you’d almost have to be deaf and blind to have not heard or read about using that tool. It’s advanced stuff and my own sense is that it’s in many ways a tool of last resort. কিন্তু, আপনি এটি প্রয়োজন মনে করি কিন্তু সত্যিই জানা না থাকলে কিভাবে, মাইকেলের লেখার আপ এই বিষয়ের উপর একটি মহান টিউটোরিয়াল মত মনে হয়.

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

টুইটারে আমার অনুসরণ http://www.twitter.com/pagalvin

ক্যালেন্ডার দেখুন ক্যালেন্ডার আইটেম বাছাই

আমি একটি নির্দিষ্ট দিনে প্যানেল আলোচনা ট্র্যাক করতে একটি ক্যালেন্ডার ব্যবহার করছি,,en,আমি দুটি সেশন আছে,,en,সকালে এবং বিকালে,,en,আমি একটি দৃশ্য যে দেখায় সকাল সেশন শুধুমাত্র একটি সেশনে আইডি মাধ্যমে বর্ণানুক্রমে তালিকাভুক্ত তৈরি করতে চান,,en,এই কাজ করা সম্ভব একটি সামান্য চতুর হয়,,en,আমি সহজে ঠিক যে দিনের ঘটনা দেখানোর সময় একটি ফিল্টার করা দৃশ্য তৈরি করতে পারেন,,en,ক্যালেন্ডার ঐ সমস্ত ঘটনা দেখাব এবং যদি তারা সব একই ঘন্টা সঞ্চালিত,,en,এটা তাদের পাশাপাশি তালিকাবদ্ধ ঘন্টা স্লটে,,en,দারুণ,,en,চতুর অংশ যে,,en,এটা তাদের আইডি বিন্যাসে তালিকা করতে চায়,,en,যদি আমি জুড়ুন "সেশন 02,,en,এবং তারপর "সেশন 01,,en,তাদের সেশন আইডি অনুক্রমে তালিকা দেখতে,,en,ওয়েব ইউজার ইন্টারফেস সহযোগে দর্শন কনফিগার,,en,ভাগ্য নেই,,en,সেখানে আইটেম সাজাতে এই ভাবে কোন অপশন আছে,,en,ক্যালেন্ডার দৃশ্যে বাছাই ক্যালেন্ডার চলছে মন্তব্য,,en,এল Hibbs,,en. I have two sessions: morning and afternoon. I want to create a view that shows morning sessions only listed alphabetically via a session ID. This is a little tricky to accomplish (আমি সুস্পষ্ট বাস্তব কিছু মিস না করলে).

I can easily create a filtered view showing just that day’s events. The calendar will show all those events and if they all take place on the same hour, it lists them side by side in the hour slot. That’s great. The tricky part is that, ডিফল্টরূপে, it wants to list them in ID format. সুতরাং, if I add "Session 02" and then "Session 01" ক্যালেন্ডারে, এটা যাতে তাদের দেখায় (I.E, অধিবেশন 02 এবং তারপর সেশন 01). To list them in Session ID order, আমি এই জিনিস চেষ্টা চিন্তা:

  1. Configure the view using the web user interface. No luck. There are no options to sort items this way.

    কাজ না করে যে যেহেতু, I am now hoping there’s a CAML query somewhere in there that will allow me to override the sort. CQWP lets me make that kind of change, হয়তো ক্যালেন্ডার হিসাবে ভাল হবে?

  2. ওয়েব অংশ সম্পাদনা করুন, look for an "export" ফাংশন এবং … BZZZT! I can’t export its XML. There is no export option.

    I’m still holding out hope that I can find and modify some CAML query. Since I can’t export the web part, যে SharePoint ডিজাইনার পাতা.

  3. I add the calendar web part to a sandbox site and open that site using SharePoint Designer. I look at the markup for the web part and I find what I’m looking for. It’s encoded madness, কিন্তু এটি আছে: "<ListViewXml …. >এনকোড করা পাগলামি</ListViewXml>". বিশেষভাবে, এই জহর আছে:

<ক্যোয়ারী>
<যেখানে>
<DateRangesOverlap>
<FieldRef Name="EventDate"/>
<FieldRef Name="EndDate"/>
<FieldRef Name="RecurrenceID"/>
<Value Type="DateTime">
<মাস />
</মান>
</DateRangesOverlap>
</যেখানে>
<OrderBy><FieldRef Name="Session_x0020_ID" /></OrderBy>
</ক্যোয়ারী>

(আমি সঙ্কেতমুক্ত করেছি &LT;'গুলি এবং &জি.টি. এর এবং স্বচ্ছতার দোহাই জন্য একাধিক লাইন তাদের খুঁজে বিভক্ত).

কে <OrderBy> সেশন আইডি দ্বারা বিট এবং এটা এখন বিশৃঙ্খলভাবে, না অভ্যন্তরীণ তালিকা আইটেম আইডি.

পেল্লায় ডগা হে’ আপনি টুপি Becky Isserman Isha Sagi এর ব্লগ পোস্টে তার মন্তব্যের জন্য: http://www.sharepoint-tips.com/2008/07/caml-sorting-by-file-name.html. I wouldn’t have put the <OrderBy> তার মন্তব্য ছাড়া যথাস্থানে.

আমি শীঘ্রই স্ক্রিন শট সঙ্গে এই পর্যন্ত আরো পরিষ্কারভাবে লিখতে আশা করি, কিন্তু ক্ষেত্রে আমি কি না, অন্তত আমি এই অনেক করেনি.

</শেষ>

SharePoint বৈশিষ্ট্য & সমাধান ম্যানেজমেন্ট — CRUD মধ্যে হবে ভুলবেন না (অথবা ঐ ব্যাপার জন্য ডি)

আমরা সম্মিলিতভাবে SharePoint সমাধান বিষয়ে সময় চিন্তা একটি মহান চুক্তি ব্যয় — কিভাবে তাদের তৈরি করা, যা এই সরঞ্জামটি ব্যবহার করার, তারা স্থাপন করতে ব্যর্থ হলে কি হবে, টাইমার কাজ, scopes, প্রভৃতি. We spend so much time thinking about the up-front bits that it’s easy to forget that we need to retract them as well. Retracting solutions is probably more difficult, একটি ধারণাগত নকশা দৃষ্টিকোণ থেকে, than deploying them. Deployment is basically a cookbook affair. Typically, একটি বৈশিষ্ট্য ইনস্টল, হয়তো একটি বৈশিষ্ট্য রিসিভার একটি তালিকা মধ্যে কিছু তথ্য লোড করা আছে, that sort of thing. কিন্তু, ফিরিয়ে নেওয়া সম্ভাব্য অধিক জটিল.

একটি প্রদত্ত সমাধান এই মত হস্তনির্মিত তৈরি করতে পারে:

  • বিষয়বস্তু প্রকার
  • তালিকা সংজ্ঞা
  • সাইট সংজ্ঞা
  • তালিকার মধ্যে অন্তর্ভুক্ত তথ্য
  • এমনকি রিসিভার
  • InfoPath ফরম

তালিকায় যায়.

এটি সঠিকভাবে যারা হস্তনির্মিত instantiates যে একটি সমাধান ডিজাইন অবশ্যই গুরুত্বপূর্ণ সময়, it’s just as important to consider the update and delete cases. If your solution creates a new list and populates that list with data, সমাধান প্রত্যাহৃত হলে কি? In some cases, the list should be deleted. In other cases, it should be left intact for historical purposes. Your business requirements will guide you to the right decision.

এই সাহায্য, create a matrix that lists each artifact your solution deploys to SharePoint. List three columns per artifact, তৈরি করার জন্য এক, আপডেট এবং মুছে দিন. For each case, যে অপারেশন জন্য সঠিক ফলাফল নির্ধারণ.

This sort of analysis is obviously best done before the solution is ever deployed to a SharePoint farm. কিন্তু, ধূমপান চাই, it’s never too late to start doing things correctly. Create that matrix and develop a plan to address the missing update/delete scenarios. It may be a hard problem to solve, কিন্তু অন্তত আপনি সমস্যা সামনে একটি বাক্স রাখা হবে.

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

টুইটারে আমার অনুসরণ http://www.twitter.com/pagalvin

Technorati বিভাগ:

কুইক ফিক্স: ওয়েব সেবা SharePoint সঙ্গে যে গর্ভনাটিকা, InvalidOperationException

একটি মিলিয়ন বছর পূর্বে, I helped developed a web service that was invoked via a custom action for a SharePoint Designer workflow. এই সপ্তাহে, ক্লায়েন্ট উত্পাদন তা সরানো চেয়েছিলেন (পরিশেষে!) আমরাও.

কাস্টম কর্ম কাজ জরিমানা, কিন্তু ওয়েব সেবা এটি অবস্থিত নি, দান এই ত্রুটি আমাদের:

System.InvalidOperationException: This operation can be performed only on a computer that is joined to a server farm by users who have permissions in SQL Server to read from the configuration database. To connect this server to the server farm, use the SharePoint Products and Technologies Configuration Wizard, located on the Start menu in Administrative Tools.
at Microsoft.SharePoint.Administration.SPWebApplication.Lookup(URI requestUri)

Turns out that I forgot to add the service to the SharePoint application pool in IIS. Once I did that, এটি সূক্ষ্ম কাজ.

This MSDN forum posting gave me the clue I needed: http://social.msdn.microsoft.com/Forums/en-US/sharepointdevelopment/thread/2c97c004-7118-4e06-a62c-b2b0ac07ac99

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

Follow me on twitter: http://twitter.com/pagalvin

Technorati বিভাগ:

দ্রুত এবং সহজ: SPItemList এর SPFolder পান

আমি এই সমস্যা এবং চলমান গুগল বুঝতে মনে হচ্ছে না কি করতে চান রাখতে, তাই আমি মূর্ত আমি এই লিখে দিন.

আমি গত সপ্তাহে বা দুটি হয়েছি ঘটনা রিসিভার ডিবাগ অনেকটা এরকম. The ER is defined against a document library. The individual items in the document library are tightly related to their parent folders. সুতরাং, I am always getting the folder of the item for various manipulations. While debugging, আমি যার আইডি আমি জানি একটি নির্দিষ্ট আইটেম জন্য একটি ফোল্ডার এর মেটাডেটা আপডেট করার প্রয়োজন.

এখানে একটু কনসোল আবেদন (খামার সার্ভার চালানো পরিকল্পিত) যে দুটি আর্গুমেন্ট লাগে: একটি আইটেম এর আইডি এবং একটি ক্ষেত্র ধার্য একটি মান, "Approval Status". It hard codes a lot of stuff and has no error checking.

কোড হার্ড কোডেড সাইট আপ দেখায়, gets a hard coded document library and then finds the indicated item. It then finds the parent folder of that item and assigns the status value.

The key lesson here for me is that SPItem doesn’t get you access to the folder. You need to use SPListItem.File.

যে কেউ তার সমালোচনায় অফার বা কোন আইটেমের ফোল্ডার পেতে একটি ভাল উপায় সুপারিশ দেখাশোনা করলে, একটি মন্তব্য করুন.

<কোড>
ব্যবহার সিস্টেম;
ব্যবহার System.Collections.Generic;
ব্যবহার System.Text;
ব্যবহার Microsoft.SharePoint;
ব্যবহার System.Collections;

নামস্থান Conchango
{
    /// <সারাংশ>
 /// </সারাংশ>
 বর্গ ManualFolderUpdate
    {
        অচর অনধিকৃত মুখ্য(স্ট্রিং[] ARGS)
        {
            স্ট্রিং msh = "ManualFolderUpdate (v1.0): "; // msh = "Message Header"

 কনসোল.WriteLine(msh + "Starting up.  আমি গত 08/04/08 তারিখে ছিল.");

            স্ট্রিং URL টি = http://localhost/xyzzy;

            ব্যবহার (SPSite oSPSite = নতুন SPSite(url-))
            {

                ব্যবহার (SPWeb oSPWeb = oSPSite.OpenWeb())
                {
                    SPList docLib = oSPWeb.Lists["Documents"];

                    কনসোল.WriteLine(msh + "Got the document library.");

                    কনসোল.WriteLine(msh + "Doc lib item count: [" + docLib.ItemCount + "].");

                    int-এ FolderID = 0;
                    স্ট্রিং NewStatus = "xyzzy";

                    FolderID = সিস্টেম.রূপান্তর.ToInt32(ARGS[0].ToString());
                    কনসোল.WriteLine("Seeking folder for item: [" + FolderID + "].");

                    SPListItem li = docLib.GetItemById(FolderID);

                    SPFolder thisItemFolder = li.File.ParentFolder;

                    কনসোল.WriteLine(msh + "Got the parent folder.");

                    NewStatus = ARGS[1].ToString();
                    কনসোল.WriteLine("Setting status to [" + NewStatus + "].");

                    কনসোল.WriteLine("Press return to commit the update or CTRL-C to abort.");

                    কনসোল.ReadLine();

                    thisItemFolder.Item["Approval Status"] = NewStatus;
                    thisItemFolder.Item.Update();

                    কনসোল.WriteLine(msh + "Finished updating the folder.  প্রস্থান.");

                } // SPWeb ব্যবহার

            } // SPSite ব্যবহার

 কনসোল.WriteLine(msh + "Finished.");

        } // মুখ্য

    } // ক্লাস foldersync
} // নামস্থান
</কোড>

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

SharePoint স্বনির্ধারিত কর্ম গোপন

বেশ কয়েক মাস আগে, একটি প্রকল্প সময় ক্লায়েন্টের জন্য কাজ, I created a feature. Among other things, যে বৈশিষ্ট্য একটি কাস্টম কর্ম নির্ধারিত (এই সাইট সেটিংস অধীন প্রদর্শিত). The only purpose for this custom action was to demonstrate to me that the feature activation was working as expected. মূলত, I used it as a crude form of debugging.

Much to my embarrassment, this debugging artifact made its way from dev to UAT and to production before someone got around to asking, "what is this xyzzy link?"

দ্বারা বর্তমানে, we’re in production and I really don’t want to uninstall the feature, fix elements.xml and then reinstall.

Todd Bleaker pointed out an easy way to handle it. In his words:

"CustomActions are not copied into the database, they are read directly from the Elements.xml file and copied into application state at runtime. সুতরাং, you don’t need to deactivate, uninstall, reinstall, and reactivate the Feature to remove the CustomAction. Just remove it from the Elements.xml file and recycle the application pool(গণ) effected. The next time the Feature is in scope, you won’t see the CustomAction anymore."

I followed his instructions and, স্বভাবত, they work.

আমার কেস, this is a department level installation with just a single WFE. If you find yourself with this problem in future and with multiple WFE’s, I believe you’ll have to make the change in each.

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

Technorati বিভাগ: ,

কুইক ফিক্স: SharePoint সাইট ব্যবহার ছোঁড়ার [HttpException (0x80004005): অনুরোধের সময় শেষ.]

One of my developer colleagues was working on a project this week and ran into a timeout problem while working on building some crazy web part. His web part was fine, কিন্তু "হঠাৎ" একটি সম্পর্কহীন সাইট হয়ে ওঠে খুব ধীর এবং প্রায়শই এই ত্রুটির সঙ্গে সময় শেষ:

[HttpException (0x80004005): অনুরোধের সময় শেষ.]

I logged in and saw that several other sites were just fine. I suspected that there were some hidden web parts on the page and using বিশ্বাসভাজন ?বিষয়বস্তু = 1 ডিবাগ কৌশল, আমি আসলে এটি নি 11 পাতা ওয়েব অংশ, only two of which were visible. Even better (একটি let's-আশা-i-এটি-কিছু-কুশ্রী-এখানে যে আমি-নির্ধারণ করতে পারেন দৃষ্টিকোণ থেকে), three of those closed web parts had a name of "Error".

আমি ঐ ওয়েব অংশ মুছে ফেলা (যা নিজেই একটি আশ্চর্যজনক দীর্ঘ সময়) and that solved the problem. For today 🙂

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

Technorati বিভাগ:

WSS থেকে SSRS ওয়েব সেবা Invoking / FBA পরিবেশ মধ্যে শৈবাল

আমরা "CreateSubscription আবাহন করা প্রয়োজন" method on an SSRS web service that is hosted in an FBA managed MOSS environment from a custom web part. We kept getting variations of:

  • 401: না অনুমোদিত
  • অবজেক্ট সরানো

"বস্তু সরানো" বার্তাটি ছিলো সবচেয়ে আকর্ষণীয় কারণ এটা বলার অপেক্ষা রাখে না হয় যে "বস্তু" (আমাদের SSRS সেবা) তিনি "সরানো" to login.aspx. This clearly meant we had some kind of authentication problem.

আমি ঘটনাক্রমে আমি বুঝতে পেরেছি যে তালিকা ভুক্ত একটি ব্লগ এন্ট্রি by Robert Garret that described how to invoke a general purpose WSS/MOSS web service living inside an FBA environment. Note that I can’t link directly to the article (হিসাবে 06/09/08) because it wants to authenticate. The link I provide brings you to an "all posts" view and you can locate the specific article by searching for "Accessing MOSS Web Services using Forms Based Authentication".

এখানে কোড আমাদের জন্য যে কাজ:

ReportingService2006 টকা = শূন্য; 
// বিশুদ্ধতা প্রমাণ করা প্রমাণীকরণ প্রমাণীকরণ = নতুন প্রমাণীকরণ(); 
auth.Url = "HTTP://URL-/ _vti_bin / Authentication.asmx";
auth.CookieContainer =
নতুন CookieContainer();
LoginResult ফলে = auth.Login("userid", "password");
যদি (result.ErrorCode == LoginErrorCode.NoError) 
{
// কোনো ত্রুটি, তাই কুকি পাবেন.
CookieCollection কুকিজ = auth.CookieContainer.GetCookies(নতুন URI(auth.Url));
কুকি authCookie = কুকি[result.CookieName];
প্রতি =
নতুন ReportingService2006();
rs.Url =
"HTTP://server/_vti_bin/ReportServer/ReportService2006.asmx";
rs.CookieContainer =
নতুন CookieContainer();
rs.CookieContainer.Add(authCookie);
}
চেষ্টা
{
  rs.CreateSubscription(প্রতিবেদন, extSettings, নিম্নক্রমে, eventType, matchData, parameters1);
}
ধরা (ব্যতিক্রম ভূতপূর্ব)
{
  Console.WriteLine(ex.Message.ToString());
}

আমি কিছু ভালো কাজ ব্যাখ্যা:

  • আমাদের ওয়েব অংশ প্রমাণীকরণ পরিষেবা ডায়াল আপ এবং বলে প্রয়োজন, "Hey, টনি, এটা সম্পর্কে এর!".
  • প্রমাণীকরণ পরিষেবা উত্তর উক্তি, "Hey, I know you. How are the kids? Here’s a token."
  • আমরা SSRS পরিষেবা আপ কল এবং বলে, "Tony sent me, এখানে টোকেন এর."

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

দ্রুত এবং সহজ: ব্যবস্থা একটি ওয়েব সাইটের সি ইন SharePoint অবজেক্ট মডেল ব্যবহার #

I tried searching for a little snippet code that would show how I can create a new SPWeb in a site collection. I didn’t find it as quickly or easily as I expected so I thought I’d slap together a little entry on the subject.

এই কোড একটি নতুন উইকিবই সাইট নির্মাণ:

 SPSite siteCollection;

    siteCollection = নতুন SPSite("http://conchang-o9l8qi");

    SPWeb W = siteCollection.OpenWeb();

    w.Webs.Add("xyzzy", "xyzzy Title",
        "xyzzy description", 1033, SPWebTemplate.WebTemplateWIKI, মিথ্যা, মিথ্যা);

My initial searches failed because I was looking for phrases like "provision a web site using sharepoint object model" and the like.

যদি আপনি অনুসন্ধান for "Webs.Add()", আপনি খুব দরকারী ব্লগ এন্ট্রি একটি সংখ্যা খুঁজে পাবেন, MSDN articles and SDK documentation that go into depth on this subject. I definitely recommend এই সাইটে.

</শেষ>

আমার ব্লগ এর জন্য সাবস্ক্রাইব করুন.

Technorati বিভাগ: